vue中本地储存实时监听

作者: 源大侠 | 来源:发表于2023-04-20 17:02 被阅读0次

项目情况:比如 在同一个页面里边 不同位置 两个变量的呈现都是使用的本地储存且一个变量修改,第二个变量也要实时变化 在正常情况下 修改一个的值后储存起来 在不刷新页面的情况下 另一个是不会变化的,所以就要用到本地储存的实时刷新

  1. 现在main.js中注册全局方法,比如要监听的本地储存key值为‘changeData’
Vue.prototype.resetSetItem = function (key, newVal) {
   if (key === 'changeData') {
 
       // 创建一个StorageEvent事件
       var newStorageEvent = document.createEvent('StorageEvent');
       const storage = {
           setItem: function (k, val) {
               sessionStorage.setItem(k, val);
 
               // 初始化创建的事件
               newStorageEvent.initStorageEvent('setItem', false, false, k, null, val, null, null);
 
               // 派发对象
               window.dispatchEvent(newStorageEvent)
           }
       }
       return storage.setItem(key, newVal);
   }
}

2 如何触发

在一个路由(比如路由A)存储值得时候,使用下面的方法:

this.resetSetItem('changeData', this.value);

3、如何监听

如果在另外一个路由(比如路由B)中,我们想根据changeData的变化来请求接口刷新页面数据的时候,可以在这个路由中created钩子函数中监听

window.addEventListener('setItem', ()=> {
    this.newVal = sessionStorage.getItem('changeData');
})

相关文章

  • vue3.0 监听本地存储

    1. 现在main.js中注册全局方法,比如要监听的本地储存key值为‘changeData’ Vue.proto...

  • input框定位光标

    vue重置input光标位置, 在input输入加入空格,光标实时监听出错 vue中手机输入加入空格 123 *...

  • vue中watch详解(转)

    vue中,watch用来监听数据变化。如:需要监听输入框数据变化来实时进行搜索等。简单的写法: 函数名也可以通过字...

  • vue 中 v-model语法糖实现原理

    v-model 语法糖, 在vue组件中相当于 v-model 的实现通过实时监听input时间把值实时赋给v-m...

  • vue 项目中通过监听 localStorage 的变化进行父子

    vue实时监听 localStorage 变化 应用场景: 1、页面B需要实时获取页面A数据更改 2、父子页面之间...

  • vue中 localStorage的使用方法(详解)

    vue中实现本地储存的方法:localStorage,在HTML5中,新加入了一个localStorage特性,这...

  • iOS 监听本地文件复制进度

    做文件共享的时候,iTunes往app导入本地视频,实时监听文件的复制进度

  • Vue 记事

    嵌套路由简易写法 Vue setInterval 使用 Vue 组件中添加监听 添加监听: handleGloba...

  • 数据双向绑定方面笔记

    一、vue项目不能够实时监听(双向绑定)动态生成的数据; 上面的案例中,obj1.txt能够进行双向绑定,但是ob...

  • vue的vuex监听

    vue如何在非vue文件中监听vuex数据的变更? 通常我们在vue文件中监听数据的变更,尤其是vuex中数据的变...

网友评论

    本文标题:vue中本地储存实时监听

    本文链接:https://www.haomeiwen.com/subject/quarjdtx.html