• vuex数据持久化


    vuex可以进行全局的状态管理,但刷新后刷新后数据会消失,这是我们不愿意看到的。怎么解决呢,我们可以结合本地存储做到数据状态持久化,也可以通过插件vuex-persistedstate。


    1.手动利用HTML5的本地存储

    方法

    1、vuex的state在localStorage或sessionStorage中取值;

    2、在mutations中,定义的方法里对vuex的状态操作的同时对存储也做对应的操作。

    这样state就会和存储一起存在并且与vuex同步


    2.利用vuex-persistedstate插件

    插件的原理其实也是结合了存储方式,只是统一的配置就不需要手动每次都写存储方法。

    使用方法

    安装

    npm install vuex-persistedstate --save

    引入及配置:在store下的index.js中

    import createPersistedState from "vuex-persistedstate"

    conststore =newVuex.Store({

      // ...

      plugins: [createPersistedState()]

    })

    默认存储到localStorage


    想要存储到sessionStorage,配置如下

    import createPersistedState from "vuex-persistedstate"

    conststore = newVuex.Store({

        // ...

        plugins: [createPersistedState({

            storage:window.sessionStorage

        })]

    })

    默认持久化所有state


    指定需要持久化的state,配置如下

    import createPersistedState from "vuex-persistedstate"

    conststore = newVuex.Store({

      // ...

      plugins: [createPersistedState({

      storage:window.sessionStorage,

          reducer(val)  {

              return {

                  // 只储存state中的assessmentData

                  assessmentData: val.assessmentData

              }

          }

      })]

    })



    vuex引用多个插件的写法

    譬如:vuex提示的插件和持久化的插件一起使用,配置如下

    import createPersistedState from "vuex-persistedstate"

    import createLogger from 'vuex/dist/logger'

    // 判断环境 vuex提示生产环境中不使用

    constdebug = process.env.NODE_ENV !== 'production'

    constcreatePersisted = createPersistedState({

        storage:window.sessionStorage

    })

    exportdefaultnewVuex.Store({

      // ...

      plugins: debug ? [createLogger(), createPersisted] : [createPersisted]

    })

    plugins要是一个一维数组不然会解析错误



    作者:无脚鸟30
    链接:https://www.jianshu.com/p/e88ab068820b
    来源:简书
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
  • 相关阅读:
    实验三 进程调度模拟程序
    实验二作业调度模拟程序
    最新广商小助手 项目进展 OpenGL ES 3D在我项目中引用 代码太多只好选重要部分出来
    最后冲刺 我的项目 广商小助手
    最新一课 老师指点用Listview适配器
    安卓小学生四则运算
    大三上学期安卓一边学一边开始做一个自己觉得可以的项目 广商小助手App 加油
    我要再接再力 学更多
    用场景来规划测试工作
    阅读第13,14,15,16,17章
  • 原文地址:https://www.cnblogs.com/bamboopanders/p/13228503.html
Copyright © 2020-2023  润新知