JavaScript实时监听localStorage变化的实现方法小结

 更新时间:2024年06月30日 13:35:49   作者:接着奏乐接着舞。  
很多时候,我们在A页面通过点击之类的操作获得一个数值,然后拿到B页面使用,我们希望这个值是响应式的,当然你可以使用vue或者react的实现,这篇文章适合想偷懒或者很多后端小伙不愿意去用的使用,效果是差不多的主要是适用于任何基于JavaScript的项目,需要的朋友可以参考下

在不同窗口/选项卡中监听 localStorage 变化

当 localStorage 的数据在一个窗口/选项卡中改变时,其他同源的窗口/选项卡会触发 storage 事件。我们可以利用这个事件来监听 localStorage 的变化。

示例代码

// 添加 storage 事件监听器
window.addEventListener('storage', function(event) {
  if (event.key === 'groupID') {
    console.log('New value:', event.newValue);
  }
});

解释

  • storage 事件会在同源的其他窗口/选项卡中触发。
  • event.key 是变化的 localStorage 项的键。
  • event.newValue 是变化后的新值。

注意事项

  • 只有在不同的窗口/选项卡之间修改 localStorage 时,才会触发 storage 事件。
  • 如果在同一个窗口/选项卡中修改 localStorage,则不会触发 storage 事件。

在同一个窗口/选项卡中监听 localStorage 变化

在同一个窗口/选项卡中,storage 事件不会被触发。我们可以通过自定义事件或其他手段来实现对 localStorage 变化的监听。

方法一:使用自定义事件

  • 设置 localStorage 并触发自定义事件
function setLocalStorageItem(key, value) {
  localStorage.setItem(key, value);
  const event = new CustomEvent('localStorageChange', { detail: { key, value } });
  window.dispatchEvent(event);
}
  • 监听自定义事件
window.addEventListener('localStorageChange', function(event) {
  if (event.detail.key === 'groupID') {
    console.log('New value:', event.detail.value);
  }
});

方法二:使用定时器轮询

另一种方法是在一定时间间隔内轮询 localStorage 的值,检查是否发生变化。

let lastValue = localStorage.getItem('groupID');

setInterval(function() {
  const newValue = localStorage.getItem('groupID');
  if (newValue !== lastValue) {
    console.log('New value:', newValue);
    lastValue = newValue;
  }
}, 1000); // 每秒检查一次

方法三:使用 Proxy 对象

如果希望对所有的 localStorage 操作进行代理,可以使用 Proxy 对象。

const localStorageProxy = new Proxy(localStorage, {
  set(target, key, value) {
    target.setItem(key, value);
    const event = new CustomEvent('localStorageChange', { detail: { key, value } });
    window.dispatchEvent(event);
    return true;
  }
});

// 设置值时使用代理对象
localStorageProxy.groupID = 'newValue';

// 监听自定义事件
window.addEventListener('localStorageChange', function(event) {
  if (event.detail.key === 'groupID') {
    console.log('New value:', event.detail.value);
  }
});

示例:通过 localStorage 监听实现页面间通信

假设我们有两个页面,页面A设置 localStorage 中的 groupID 值,页面B监听 groupID 的变化并根据最新的值执行相应的逻辑。

页面A:设置 localStorage 并触发自定义事件

const sss = (node, data) => {
  let id = data.id.split('_')[1];
  alert(id);

  localStorage.setItem('groupID', id);
  // 手动触发自定义事件
  const event = new CustomEvent('localStorageChange', { detail: { key: 'groupID', value: id } });
  window.dispatchEvent(event);
};

页面B:监听自定义事件并获取最新的 groupID 值

mounted() {
  let _this = this;

  // 初次加载时获取数据
  _this.getData();

  // 使用自定义事件监听 groupID 变化
  window.addEventListener('localStorageChange', function(event) {
    if (event.detail.key === 'groupID') {
      alert('1');
      _this.getData();
    }
  });
},

methods: {
  async getData() {
    const id = localStorage.getItem('groupID');

    // 检查 id 是否存在
    if (!id) {
      this.$message({
        message: 'Group ID 不存在,请先选择一个组。',
        type: 'warning'
      });
      return;
    }

    try {
      const res = await traffic.trafficvulndel({
        page: this.formData.page_num,
        size: this.pageSize,
        search: this.formData.search_field,
        groupID: id,
        ...this.formData
      });
      
      if (res.code === 200) {
        this.tableData = res.data.assetsInfo;
        console.log(this.tableData, 'this.tableData');
        this.totalpage = res.data.count;
      } else {
        this.$message({
          message: res.msg,
          type: 'error'
        });
      }
    } catch (error) {
      console.log(error);
      this.$message({
        message: '请求失败,请稍后再试。',
        type: 'error'
      });
    }
  }
}

以上就是JavaScript实时监听localStorage变化的实现方法小结的详细内容,更多关于JavaScript监听localStorage变化的资料请关注脚本之家其它相关文章!

相关文章

  • 微信小程序封装的HTTP请求示例【附升级版】

    微信小程序封装的HTTP请求示例【附升级版】

    这篇文章主要介绍了微信小程序封装的HTTP请求,结合实例形式分析了微信小程序封装基于wx.request方法的http请求相关操作与使用技巧,并附带升级版示例供大家参考,需要的朋友可以参考下
    2019-05-05
  • js判断手机是否安装并打开app,未安装则安装app【兼容Android、ios,亲测可用】

    js判断手机是否安装并打开app,未安装则安装app【兼容Android、ios,亲测可用】

    这篇文章主要介绍了js判断手机是否安装并打开app,未安装则安装app,通过调用浏览器判断app,兼容Android、ios等系统,,需要的朋友可以参考下
    2023-05-05
  • 小程序云开发教程如何使用云函数实现点赞功能

    小程序云开发教程如何使用云函数实现点赞功能

    这篇文章主要为大家详细介绍了小程序云开发教程如何使用云函数实现点赞功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • JavaScript 代码分割的实现步骤

    JavaScript 代码分割的实现步骤

    JavaScript代码分割是一种优化策略,通过将代码拆分成较小的块,只在需要时加载,可以降低初始加载时间,减小页面体积,本文主要介绍了JavaScript代码分割的实现步骤,感兴趣的可以了解一下
    2024-01-01
  • js Canvas绘制圆形时钟效果

    js Canvas绘制圆形时钟效果

    这篇文章主要为大家详细介绍了js Canvas绘制圆形时钟效果的相关代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • JS仿Base.js实现的继承示例

    JS仿Base.js实现的继承示例

    这篇文章主要介绍了JS仿Base.js实现的继承,结合具体实例形式分析了javascript扩展操作及面向对象程序设计相关实现技巧,需要的朋友可以参考下
    2017-04-04
  • JavaScript中数字转字符串的6种方式以及性能比较

    JavaScript中数字转字符串的6种方式以及性能比较

    在JavaScript中将字符串转换为数字有多种方法,下面这篇文章主要给大家介绍了关于JavaScript中数字转字符串的6种方式以及性能比较的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-04-04
  • 用原生JS实现简单的多选框功能

    用原生JS实现简单的多选框功能

    这篇文章主要介绍了用原生JS实现简单的多选框功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-06-06
  • Three.js+React实现3D文字悬浮效果

    Three.js+React实现3D文字悬浮效果

    这篇文章主要介绍了如何利用Three.js+React制作出神奇的3D文字悬浮效果,文中的示例代码讲解详细,感兴趣的小伙伴可以动手尝试一下
    2022-03-03
  • JS Array对象入门分析

    JS Array对象入门分析

    每天一对象,今天我们也来new一个。没有系统的学过JS,没有特别的写过一个比较出色的类库,没有运用过一个很强的类库,prototype.js在进行着,慢慢的前进相信不久的将来就可以应用prototype.js来开发自己的应用程序了。
    2008-10-10

最新评论