vuex使用了sessionStorage作为数据来源后,没有初始状态,无法监控?

//获取网站信息
    const bloginfo = sessionStorage.getItem("bloginfo");
    if (bloginfo) {
      this.$store.commit("setWebsiteInfo", JSON.parse(bloginfo));
    } else {
      apiGetInfo().then((res) => {
        this.$store.commit("setWebsiteInfo", res.data);
        sessionStorage.setItem("bloginfo", JSON.stringify(res.data));
      });
    }

做了一个缓存,如果本地有数据的话,直接设置state,后面发现无法监控state的数据。vuex的初始状态也是一直有数据:
image.png

当我把本地取值的相关代码注释后,就正常了,可以监听,vuex的初始状态也没有数据了:

//获取网站信息
    // const bloginfo = sessionStorage.getItem("bloginfo");
    // if (bloginfo) {
    //   this.$store.commit("setWebsiteInfo", JSON.parse(bloginfo));
    // } else {
      apiGetInfo().then((res) => {
        this.$store.commit("setWebsiteInfo", res.data);
        sessionStorage.setItem("bloginfo", JSON.stringify(res.data));
      });
    //}

image.png

有大佬可以解惑否?

阅读 1.2k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题