vuex能够进行全局的状态管理,但刷新后刷新后数据会消失,这是咱们不肯意看到的。怎么解决呢,咱们能够结合本地存储作到数据持久化,也能够经过插件-vuex-persistedstate。vue
插件的原理其实也是结合了存储方式,只是统一的配置就不须要手动每次都写存储方法vuex
npm install vuex-persistedstate --save
复制代码
在store下的index.js中npm
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState()]
})
复制代码
默认存储到localStorage数组
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage
})]
})
复制代码
默认持久化全部statebash
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage,
reducer(val) {
return {
// 只储存state中的assessmentData
assessmentData: val.assessmentData
}
}
})]
复制代码
譬如:vuex提示的插件和持久化的插件一块儿使用,配置以下cookie
import createPersistedState from "vuex-persistedstate"
import createLogger from 'vuex/dist/logger'
// 判断环境 vuex提示生产环境中不使用
const debug = process.env.NODE_ENV !== 'production'
const createPersisted = createPersistedState({
storage: window.sessionStorage
})
export default new Vuex.Store({
// ...
plugins: debug ? [createLogger(), createPersisted] : [createPersisted]
})
复制代码
plugins要是一个一维数组否则会解析错误session