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地址