自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

所以,你是知道怎么監(jiān)聽LocalStorage的變化的?

開發(fā) 前端
很多比較出名的項(xiàng)目中,大家可以去看那些開源的項(xiàng)目中,基本很少直接使用localStorage,而是都是會封裝一層的。

前言

大家好,我是林三心,用最通俗易懂的話講最難的知識點(diǎn)是我的座右銘,基礎(chǔ)是進(jìn)階的前提是我的初心

背景

前幾天有位兄弟問我,如何去監(jiān)聽localStorage的變化呢??我確實(shí)是沒遇到過這種場景,但是我仔細(xì)想想,似乎想要達(dá)到這樣的效果,其實(shí)也不難。

解題思路

第一種:storageEvent

其實(shí)JavaScript原生就有一個(gè)監(jiān)聽localStorage變化的事件——storage,使用方法如下

window.addEventListener('storage', () => {
  // callback
})

我們來看看MDN上是怎么描述這個(gè)事件的:

圖片

也就是說,同域下的不同頁面A、B,只有本頁面修改了localStorage才會觸發(fā)對方的storage事件

但是顯然這種方案很不適用在現(xiàn)在的大部分項(xiàng)目中,畢竟這種方案太局限了,不能應(yīng)用在本頁面監(jiān)聽的場景

第二種:封裝localStroage

其實(shí)就是代理一下對localStorage進(jìn)行多一層的封裝,使得我們每次在操作localStorage的時(shí)候,都會多走一層函數(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)用于很多比較出名的項(xiàng)目中,大家可以去看那些開源的項(xiàng)目中,基本很少直接使用localStorage,而是都是會封裝一層的

責(zé)任編輯:武曉燕 來源: 前端之神
相關(guān)推薦

2023-06-02 07:32:34

localStorage?監(jiān)聽

2024-12-04 08:40:19

2013-02-27 10:27:44

GitHub

2024-02-19 00:00:00

Docker輕量級容器

2024-03-26 10:17:49

開發(fā)緩存key

2020-06-29 18:54:39

大數(shù)據(jù)新發(fā)地疫情

2024-11-26 00:45:29

free區(qū)域字段

2023-04-28 07:44:44

MyBatis查詢SQL

2021-01-21 09:09:18

時(shí)區(qū)轉(zhuǎn)換程序

2020-12-08 09:25:41

死鎖MySQL數(shù)據(jù)庫

2024-12-11 08:19:34

2021-07-19 16:11:22

智能手機(jī)科技興趣

2022-11-16 08:43:30

Node.js模塊

2014-08-22 10:14:27

2018-09-05 08:59:51

服務(wù)器DNS網(wǎng)絡(luò)

2022-05-11 09:09:42

用戶客戶

2021-01-29 13:22:58

Swagger版本OpenAPI

2022-08-25 09:08:40

微服務(wù)架構(gòu)

2012-12-21 16:57:37

手機(jī)安全個(gè)人信息泄漏個(gè)人信息安全

2021-04-26 07:53:06

DOM前端框架
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號