vuex能够进行全局的状态管理,但刷新后刷新后数据会消失,这是咱们不肯意看到的。怎么解决呢,咱们能够结合本地存储作到数据持久化,也能够经过插件-vuex-persistedstate。javascript
欢迎来点点个人我的博客 vue
方法java
这样state就会和存储一块儿存在而且与vuex同步
git
问题github
插件的原理其实也是结合了存储方式,只是统一的配置就不须要手动每次都写存储方法
vuex
使用方法npm
npm install vuex-persistedstate --save
复制代码
引入及配置数组
在store下的index.js中cookie
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState()]
})
复制代码
默认存储到localStoragesession
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage
})]
})
复制代码
想使用cookie同理
默认持久化全部state
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage,
reducer(val) {
return {
// 只储存state中的assessmentData
assessmentData: val.assessmentData
}
}
})]
复制代码
譬如:vuex提示的插件和持久化的插件一块儿使用,配置以下
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要是一个一维数组否则会解析错误
看github上的文档发现没有直接能够这样使用的方式,因此我采用建立多个实例的方式,以下
const createPersisted = createPersistedState({
storage: window.sessionStorage,
// 移除sessionState储存的device
reducer: (vuexState) => {
let sessionState = Object.assign({}, vuexState)
for (let key in sessionState) {
if (key === 'device') {
delete sessionState[key]
}
}
return sessionState
}
})
const createStorage = createPersistedState({
key: 'vuexStorage',
storage: window.localStorage,
reducer: (vuexState) => {
// localStorage只储存device信息
return vuexState.device
}
})
export default new Vuex.Store({
state,
getters,
mutations,
actions,
modules: {
device
},
strict: debug,
plugins: debug ? [createLogger(), createStorage, createPersisted] : [createStorage, createPersisted]
})
复制代码
有个思路是:写一个mutaition方法,作的事是将全部state制为初始值
点击跳转插件GITHUB地址