前端項目中監(jiān)聽localStorage的變化
背景
前幾天有位兄弟問我,如何去監(jiān)聽localStorage的變化呢??我確實是沒遇到過這種場景,但是我仔細(xì)想想,似乎想要達(dá)到這樣的效果,其實也不難。
解題思路
第一種:storageEvent
其實JavaScript原生就有一個監(jiān)聽localStorage變化的事件——storage,使用方法如下
window.addEventListener('storage', () => { // callback })
我們來看看MDN上是怎么描述這個事件的:
也就是說,同域下的不同頁面A、B,只有本頁面修改了localStorage才會觸發(fā)對方的storage事件
但是顯然這種方案很不適用在現(xiàn)在的大部分項目中,畢竟這種方案太局限了,不能應(yīng)用在本頁面監(jiān)聽的場景
第二種:封裝localStroage
其實就是代理一下對localStorage進(jìn)行多一層的封裝,使得我們每次在操作localStorage的時候,都會多走一層函數(shù),而我們就可以在這一層中去執(zhí)行監(jiān)聽的事件了,下面是簡單的代碼例子:
class CommonLocalStorage { private storage: Storage; constructor() { this.storage = window.localStorage; } set(key: string, value: any) { // 執(zhí)行監(jiān)聽的操作 return this.storage.setItem(`${prefix}${key}`, value); } get(key: string) { // 執(zhí)行監(jiān)聽的操作 return this.storage.getItem(`${prefix}${key}`); } del(key: string) { // 執(zhí)行監(jiān)聽的操作 return this.storage.removeItem(`${prefix}${key}`); } clear() { // 執(zhí)行監(jiān)聽的操作 this.storage.clear(); } } const commonStorage = new CommonLocalStorage(); export default commonStorage
這種方式也被應(yīng)用于很多比較出名的項目中,大家可以去看那些開源的項目中,基本很少直接使用localStorage,而是都是會封裝一層的
以上就是前端項目中監(jiān)聽localStorage的變化的詳細(xì)內(nèi)容,更多關(guān)于前端監(jiān)聽localStorage變化的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序 (七)數(shù)據(jù)綁定詳細(xì)介紹
這篇文章主要介紹了微信小程序數(shù)據(jù)綁定詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-09-09package.json中browser?module?main字段優(yōu)先級對比
這篇文章主要介紹了package.json中browser?module?main字段的優(yōu)先級詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07JavaScript中直接寫undefined的錯誤及用法剖析
這篇文章主要介紹了JavaScript中直接寫undefined的用法剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07JavaScript中七種流行的開源機器學(xué)習(xí)框架
今天小編就為大家分享一篇關(guān)于JavaScript中五種流行的開源機器學(xué)習(xí)框架,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-10-10JS中的every()對空數(shù)組總返回true原理分析
這篇文章主要為大家介紹了JS中的every()對空數(shù)組總返回true原理分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09微信小程序 實現(xiàn)拖拽事件監(jiān)聽實例詳解
這篇文章主要介紹了微信小程序 實現(xiàn)拖拽事件監(jiān)聽實例詳解的相關(guān)資料,在開發(fā)不少應(yīng)用或者軟件都要用到這樣的方法,這里就對微信小程序?qū)崿F(xiàn)該功能進(jìn)行介紹,需要的朋友可以參考下2016-11-11