vuex可以進(jìn)行全局的狀態(tài)管理笑撞,但刷新后刷新后數(shù)據(jù)會(huì)消失,這是我們不愿意看到的。怎么解決呢抡蛙,我們可以結(jié)合本地存儲(chǔ)做到數(shù)據(jù)持久化,也可以通過插件-vuex-persistedstate磷杏。
1通過 vuex-persistedstate這個(gè)插件溜畅,來實(shí)現(xiàn)將數(shù)據(jù)存儲(chǔ)到本地
npm install vuex-persistedstate
1
之后使用這個(gè)插件在Store中
import createPersistedState from 'vuex-persistedstate'
const store = new Vuex.Store({
modules: {
cart, //以模塊的方式導(dǎo)出,這是專屬于購物車的极祸,可以再有一個(gè)共享登陸狀態(tài)的慈格,這樣便于分類
},
plugins: [createPersistedState()] //加上這個(gè)就可以了
})
插件的原理其實(shí)也是結(jié)合了存儲(chǔ)方式,只是統(tǒng)一的配置就不需要手動(dòng)每次都寫存儲(chǔ)方法
默認(rèn)存儲(chǔ)到localStorage
想要存儲(chǔ)到sessionStorage怠晴,配置如下
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage
})]
})
想使用cookie同理
默認(rèn)持久化所有state
指定需要持久化的state,配置如下
import createPersistedState from "vuex-persistedstate"
const store = new Vuex.Store({
// ...
plugins: [createPersistedState({
storage: window.sessionStorage,
reducer(val) {
return {
// 只儲(chǔ)存state中的assessmentData
assessmentData: val.assessmentData
}
}
})]
vuex引用多個(gè)插件的寫法
譬如:vuex提示的插件和持久化的插件一起使用,配置如下
import createPersistedState from "vuex-persistedstate"
import createLogger from 'vuex/dist/logger'
// 判斷環(huán)境 vuex提示生產(chǎn)環(huán)境中不使用
const debug = process.env.NODE_ENV !== 'production'
const createPersisted = createPersistedState({
storage: window.sessionStorage
})
export default new Vuex.Store({
// ...
plugins: debug ? [createLogger(), createPersisted] : [createPersisted]
})
//**注意:plugins要是一個(gè)一維數(shù)組不然會(huì)解析錯(cuò)誤
2手動(dòng)利用HTML5的本地存儲(chǔ)
vuex的state在localStorage或sessionStorage或其它存儲(chǔ)方式中取值
在mutations,定義的方法里對(duì)vuex的狀態(tài)操作的同時(shí)對(duì)存儲(chǔ)也做對(duì)應(yīng)的操作浴捆。
這樣state就會(huì)和存儲(chǔ)一起存在并且與vuex同步
最直觀的就是蒜田,手動(dòng)寫比較麻煩。
原文鏈接:https://blog.csdn.net/qq_30841657/article/details/97099274