利用Nuxt.js做Vuex數(shù)據(jù)持久化
Nuxt.js做Vuex數(shù)據(jù)持久化
數(shù)據(jù)丟失的原因
vuex存儲的數(shù)據(jù)只是在頁面中,相當(dāng)于全局變量,頁面刷新的時候vuex里的數(shù)據(jù)會重新初始化,導(dǎo)致數(shù)據(jù)丟失。
因?yàn)関uex里的數(shù)據(jù)是保存在運(yùn)行內(nèi)存中的,當(dāng)頁面刷新時,頁面會重新加載vue實(shí)例,vuex里面的數(shù)據(jù)就會被重新賦值。
解決方法
這里將Vuex的數(shù)據(jù)存儲到localStorage中,具體看下面代碼
1. 在plugins.js文件中創(chuàng)建 store-cache.js
2. 在nuxt.config.js 中代碼如下
plugins: [ { src: '~/plugins/store-cache', ssr: false }, ],
store-cache.js 文件代碼如下
export default function(ctx) { // 離開頁面 刷新前 將store中的數(shù)據(jù)存到localStorage window.addEventListener('beforeunload', () => { localStorage.setItem("storeCache", JSON.stringify(ctx.store.state)) }); // 獲取localStorage中的store數(shù)據(jù) let storeCache = localStorage.getItem("storeCache") if (storeCache) { // 將localStorage中的store數(shù)據(jù)替換到store中 ctx.store.replaceState(Object.assign({},ctx.store.state,JSON.parse(storeCache)) ) } }
這樣就解決了Vuex刷新數(shù)據(jù)丟失的問題了,實(shí)現(xiàn)了數(shù)據(jù)持久化
VueX數(shù)據(jù)持久化和輔助函數(shù)的使用
1.數(shù)據(jù)持久化
1.1本地緩存
在項(xiàng)目中使用vuex進(jìn)行項(xiàng)目一些公共狀態(tài)的共享,可以在任意頁面中使用,避免了數(shù)據(jù)在組件中層層傳遞的繁瑣。而且vuex中的數(shù)據(jù)是響應(yīng)式的,很好的幫助我們解決了這個問題。但是vuex中的數(shù)據(jù)是保存在內(nèi)存中的,頁面刷新會重新初始化導(dǎo)致數(shù)據(jù)丟失。
我們可以使用localStorage或者sessionStorage,在mutation更改數(shù)據(jù)的時候,同時往瀏覽器本地緩存也存一份,在state取的時候也從本地緩存取一份或者用原來的。
1.2 使用第三方庫 vuex-persistedstate
npm install --save?vuex-persistedstate
使用vuex-persistedstate默認(rèn)存儲到localStorage
引入之后,配置plugins和存儲持久化的鍵名即可,就會自動在localStorage配置的鍵名下存儲state全局?jǐn)?shù)據(jù)和模塊化之后的數(shù)據(jù)
2.Vuex輔助函數(shù)的使用
vuex可以使用$store.state或者getters,$store.dispatch和commit觸發(fā)actions和mutations更新。也可以使用輔助函數(shù)。
$store的寫法最簡單且通俗易懂,但輔助函數(shù)的寫法也建議大家掌握,免得遇到有些項(xiàng)目中遇到了看不懂。
首先需要從vuex中引入輔助函數(shù)
2.1 mapState和getters
mapState可以使用數(shù)組語法也可以使用,對象語法。
當(dāng)vuex沒有模塊化的時候,可以直接使用數(shù)組語法,簡單便捷,...mapState['state中鍵名'];也可以使用對象語法,如下。模塊化之后也有兩是寫法,數(shù)組:...mapState['模塊名','鍵名'];對象:如下。getters也是兩種寫法,和state一樣,都是寫在計算屬性中。
computed: { ...mapState({ sellInfoCp: "sellerInfo" }), ...mapState({ billCp: state => state.bill.billInfo }), // ...mapGetters('bill',['bigSum']) // sellInfoCp() { // return this.$store.state.sellerInfo // } },
2.2 mapActions和mapMutations
mapActions和mapMutations都是寫在methods方法中。
也都是有兩種寫法,數(shù)組和對象寫法。
以mapMutations為例,數(shù)組:...mapMutations('模塊名',['鍵名'])
對象:...mapMutations({自定義鍵名:"模塊名/鍵名"})
methods: { // ...mapMutations('bill',['SET_AMOUNT']), ...mapMutations({ SET_AMOUNT: "bill/SET_AMOUNT" }), ...mapActions('bill', ['FETCH_AMOUNT']), },
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue使用tracking實(shí)現(xiàn)人臉識別/人臉偵測完整代碼
作為一個AI模型,人臉識別涉及到多個技術(shù)領(lǐng)域,下面這篇文章主要給大家介紹了關(guān)于vue使用tracking實(shí)現(xiàn)人臉識別/人臉偵測的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09vue結(jié)合Echarts實(shí)現(xiàn)點(diǎn)擊高亮效果的示例
下面小編就為大家分享一篇vue結(jié)合Echarts實(shí)現(xiàn)點(diǎn)擊高亮效果的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03ant design vue 清空upload組件圖片緩存的問題
這篇文章主要介紹了ant design vue 清空upload組件圖片緩存的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10vue中v-for和v-if一起使用之使用compute的示例代碼
這篇文章主要介紹了vue中v-for和v-if一起使用之使用compute的相關(guān)知識,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05Vue?axios和vue-axios的關(guān)系及使用區(qū)別
axios是基于promise的HTTP庫,可以使用在瀏覽器和node.js中,它不是vue的第三方插件,vue-axios是axios集成到Vue.js的小包裝器,可以像插件一樣安裝使用:Vue.use(VueAxios, axios),本文給大家介紹Vue?axios和vue-axios關(guān)系,感興趣的朋友一起看看吧2022-08-08