首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Vuex createPersistedState部分持久化不起作用

Vuex createPersistedState部分持久化不起作用
EN

Stack Overflow用户
提问于 2021-06-23 01:05:32
回答 3查看 182关注 0票数 1

遵循持久化状态文档(https://www.npmjs.com/package/vuex-persistedstate),我尝试部分持久化状态,如下所示:

代码语言:javascript
运行
复制
export default new Vuex.Store({
  state: {
    user: {},
    signupLayout: false,
    adminLayout: false,
    sidebarOpen: false,
    homeLayout: false, /* New - 6/01/2021 */
    cloudinary: {
      cloud_name: "*****",
      base_upload_preset: "*****",
      channel_header_upload_preset: "*****",
      profile_image_upload_preset: "*****",
      audio_upload_preset: "*****",
      cover_image_upload_preset: "*****",
    },
    plugins: [createPersistedState({
      paths: ["user", "signupLayout", "adminLayout", "sidebarOpen", "homeLayout"]
    })],
  },
  mutations: {
    setUser(state, user) {
      state.user = user;
    },
    setSignupLayout(state, bool) {
      state.signupLayout = bool;
    },
    setSidebarOpen(state, bool) {
      state.sidebarOpen = bool;
    },
    setAdminLayout(state, bool) {
      state.adminLayout = bool;
    },

    /* New - 6/01/2021 */
    setHomeLayout(state, bool) {
      state.homeLayout = bool;
    },
  },

但是,当我尝试运行代码时,什么都没有持久化。谁能告诉我为什么,以及如何修复?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2021-07-01 02:36:38

插件属性的位置不正确。应该是这样的。

代码语言:javascript
运行
复制
import Vuex from 'vuex'
import createPersistedState from 'vuex-persistedstate'
    
export default new Vuex.Store({
  state: {},
  mutations: {},
  actions: {},
  modules: {},
  plugins: [createPersistedState()],
})
票数 1
EN

Stack Overflow用户

发布于 2021-06-23 01:35:50

vuex-persistedstate插件可能不需要保存您的默认状态,因为没有任何变化。我在你的vuex商店里也没看到任何突变。persistedstate插件在状态突变上工作,所以用一个突变(vuex docs mutations page)修改你的状态,插件就应该开始工作了。

票数 0
EN

Stack Overflow用户

发布于 2021-06-24 22:35:05

这是答案非常简单的时候之一。原来我在state属性对象中有plugins属性。我只是把它移到了国家财产之外,现在一切都按预期工作了。

代码语言:javascript
运行
复制
export default new Vuex.Store({
  state: {
    user: {},
    signupLayout: false,
    adminLayout: false,
    sidebarOpen: false,
    homeLayout: false, /* New - 6/01/2021 */
    cloudinary: {
      cloud_name: "*****",
      base_upload_preset: "*****",
      channel_header_upload_preset: "*****",
      profile_image_upload_preset: "*****",
      audio_upload_preset: "*****",
      cover_image_upload_preset: "*****",
    },
  },
  plugins: [createPersistedState({
    paths: ['user', 'signupLayout', 'adminLayout', 'sidebarOpen', 'homeLayout']
  })],
  mutations: {
    setUser(state, user) {
      state.user = user;
    },
    setSignupLayout(state, bool) {
      state.signupLayout = bool;
    },
    setSidebarOpen(state, bool) {
      state.sidebarOpen = bool;
    },
    setAdminLayout(state, bool) {
      state.adminLayout = bool;
    },

    /* New - 6/01/2021 */
    setHomeLayout(state, bool) {
      state.homeLayout = bool;
    },
  },
});
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68087950

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档