当前位置:   article > 正文

vue 监听 sessionStorage 中值的变化_vue监听sessionstorage变化

vue监听sessionstorage变化

通过 watch 可以监听vue实例已有属性的变化,那么怎样监听 sessionStorage 中值的变化呢?

使用场景

以角色为例,将当前用户的角色存入 sessionStorage 的 role 中,切换角色后,首先要修改 sessionStorage 中的 role 值,接着需从 sessionStorage 中取出新的 role 值显示在页面上。

重难点: 当 sessionStorage 中的 role 值改变时,需同步更新所有页面的 role 值。

解决方案

使用公共组件封装各个页面对 role 值的显示,并在其中监听 sessionStorage 的变化,实时更新页面的 role 值

核心代码

将 sessionStorage 的变化注册为全局事件 setItem
( 若想全局使用,则下方代码写在main.js中 )

import Vue from "vue";

Vue.prototype.setSessionItem = function (key, newVal) {
  // 创建 StorageEvent 事件
  let newStorageEvent = document.createEvent("StorageEvent");
  const storage = {
    setItem: function (k, val) {
      sessionStorage.setItem(k, val);

      // 初始化 StorageEvent 事件
      newStorageEvent.initStorageEvent(
        "setItem", // 事件别名
        false,
        false,
        k,
        null,
        val,
        null,
        null
      );

      // 派发事件
      window.dispatchEvent(newStorageEvent);
    },
  };
  return storage.setItem(key, newVal);
};
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

在页面创建时添加对 setItem 事件的监听

  mounted() {
    // 添加对 sessionStorage 的监听
    window.addEventListener("setItem", () => {
      this.role = sessionStorage.getItem("role");
    });
  },
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

在页面销毁时移除对 setItem 事件的监听

  beforeDestroy() {
    // 移除对 sessionStorage 的监听
    window.removeEventListener("setItem", () => {});
  },
  • 1
  • 2
  • 3
  • 4

完整范例

首次进入页面的效果
在这里插入图片描述
点击按钮修改角色后
在这里插入图片描述
完整代码如下:

<template>
  <div style="padding: 20px">
    <p>sessionStorage中“role” 的值为 —— {{ role }}</p>

    <el-button type="primary" @click="change"
      >将sessionStorage中“role” 的值改为“管理员”</el-button
    >
  </div>
</template>

<script>
import Vue from "vue";

Vue.prototype.setSessionItem = function (key, newVal) {
  // 创建 StorageEvent 事件
  let newStorageEvent = document.createEvent("StorageEvent");
  const storage = {
    setItem: function (k, val) {
      sessionStorage.setItem(k, val);

      // 初始化 StorageEvent 事件
      newStorageEvent.initStorageEvent(
        "setItem", // 事件别名
        false,
        false,
        k,
        null,
        val,
        null,
        null
      );

      // 派发事件
      window.dispatchEvent(newStorageEvent);
    },
  };
  return storage.setItem(key, newVal);
};
export default {
  data() {
    return {
      role: sessionStorage.getItem("role") || "未定义角色",
    };
  },
  mounted() {
    // 添加对 sessionStorage 的监听
    window.addEventListener("setItem", () => {
      this.role = sessionStorage.getItem("role");
    });
  },
  beforeDestroy() {
    // 移除对 sessionStorage 的监听
    window.removeEventListener("setItem", () => {});
  },
  methods: {
    change() {
      // 修改 sessionStorage 中的值
      this.setSessionItem("role", "管理员");
    },
  },
};
</script>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号