当前位置:首页 > 科技  > 软件

所以,你是知道怎么监听LocalStorage的变化的?

来源: 责编: 时间:2024-04-11 09:04:44 236观看
导读前言大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心背景前几天有位兄弟问我,如何去监听localStorage的变化呢??我确实是没遇到过这种场景,但是我仔细想想,似乎想要达到这样的效果

前言

大家好,我是林三心,用最通俗易懂的话讲最难的知识点是我的座右铭,基础是进阶的前提是我的初心Eas28资讯网——每日最新资讯28at.com

背景

前几天有位兄弟问我,如何去监听localStorage的变化呢??我确实是没遇到过这种场景,但是我仔细想想,似乎想要达到这样的效果,其实也不难。Eas28资讯网——每日最新资讯28at.com

解题思路

第一种:storageEvent

其实JavaScript原生就有一个监听localStorage变化的事件——storage,使用方法如下Eas28资讯网——每日最新资讯28at.com

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

我们来看看MDN上是怎么描述这个事件的:Eas28资讯网——每日最新资讯28at.com

图片Eas28资讯网——每日最新资讯28at.com

也就是说,同域下的不同页面A、B,只有本页面修改了localStorage才会触发对方的storage事件Eas28资讯网——每日最新资讯28at.com

但是显然这种方案很不适用在现在的大部分项目中,毕竟这种方案太局限了,不能应用在本页面监听的场景Eas28资讯网——每日最新资讯28at.com

第二种:封装localStroage

其实就是代理一下对localStorage进行多一层的封装,使得我们每次在操作localStorage的时候,都会多走一层函数,而我们就可以在这一层中去执行监听的事件了,下面是简单的代码例子:Eas28资讯网——每日最新资讯28at.com

class CommonLocalStorage {  private storage: Storage;  constructor() {    this.storage = window.localStorage;  }  set(key: string, value: any) {    // 执行监听的操作    return this.storage.setItem(`${prefix}${key}`, value);  }  get(key: string) {    // 执行监听的操作    return this.storage.getItem(`${prefix}${key}`);  }  del(key: string) {    // 执行监听的操作    return this.storage.removeItem(`${prefix}${key}`);  }  clear() {    // 执行监听的操作    this.storage.clear();  }}const commonStorage = new CommonLocalStorage();export default commonStorage

这种方式也被应用于很多比较出名的项目中,大家可以去看那些开源的项目中,基本很少直接使用localStorage,而是都是会封装一层的Eas28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-82753-0.html所以,你是知道怎么监听LocalStorage的变化的?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 一文读懂Cache一致性原理

下一篇: 我们一起理解 React 服务端组件

标签:
  • 热门焦点
  • K60至尊版狂暴引擎2.0加持:超177万跑分斩获性能第一

    Redmi的后性能时代战略发布会今天下午如期举办,在本次发布会上,Redmi公布了多项关于和联发科的深度合作,以及新机K60 Ultra在软件和硬件方面的特性,例如:“K60 至尊版,双芯旗舰
  • 红魔电竞平板评测:大屏幕硬实力

    前言:三年的疫情因为要上网课的原因激活了平板市场,如今网课的时代已经过去,大家的生活都恢复到了正轨,这也就意味着,真正考验平板电脑生存的环境来了。也就是面对着这种残酷的
  • 7月安卓手机性价比榜:努比亚+红魔两款新机入榜

    7月登场的新机有努比亚Z50S Pro和红魔8S Pro,除了三星之外目前唯二的两款搭载超频版骁龙8Gen2处理器的产品,而且努比亚和红魔也一贯有着不错的性价比,所以在本次的性价比榜单
  • 印度登月最关键一步!月船三号今晚进入环月轨道

    8月5日消息,据印度官方消息,月船三号将于北京时间今晚21时30分左右开始近月制动进入环月轨道。这是该探测器能够成功的最关键步骤之一,如果成功将开始围
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • 在线图片编辑器,支持PSD解析、AI抠图等

    自从我上次分享一个人开发仿造稿定设计的图片编辑器到现在,不知不觉已过去一年时间了,期间我经历了裁员失业、面试找工作碰壁,寒冬下一直没有很好地履行计划.....这些就放在日
  • ESG的面子与里子

    来源 | 光子星球撰文 | 吴坤谚编辑 | 吴先之三伏大幕拉起,各地高温预警不绝,但处于厄尔尼诺大“烤”之下的除了众生,还有各大企业发布的ESG报告。ESG是“环境保
  • SN570 NVMe SSD固态硬盘 价格与性能兼具

    SN570 NVMe SSD固态硬盘是西部数据发布的最新一代WD Blue系列的固态硬盘,不仅闪存技术更为精进,性能也得到了进一步的跃升。WD Blue SN570 NVMe SSD的包装外
  • Meta盲目扩张致超万人被裁,重金押注元宇宙而前景未明

    图片来源:图虫创意日前,Meta创始人兼CEO 马克·扎克伯发布公开信,宣布Meta计划裁员超11000人,占其员工总数13%。他公开承认了自己的预判失误:“不仅
Top