亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

利用Nuxt.js做Vuex數(shù)據(jù)持久化

 更新時(shí)間:2023年10月11日 11:40:43   作者:Vue安夏  
這篇文章主要介紹了利用Nuxt.js做Vuex數(shù)據(jù)持久化問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

Nuxt.js做Vuex數(shù)據(jù)持久化

數(shù)據(jù)丟失的原因

vuex存儲(chǔ)的數(shù)據(jù)只是在頁(yè)面中,相當(dāng)于全局變量,頁(yè)面刷新的時(shí)候vuex里的數(shù)據(jù)會(huì)重新初始化,導(dǎo)致數(shù)據(jù)丟失。

因?yàn)関uex里的數(shù)據(jù)是保存在運(yùn)行內(nèi)存中的,當(dāng)頁(yè)面刷新時(shí),頁(yè)面會(huì)重新加載vue實(shí)例,vuex里面的數(shù)據(jù)就會(huì)被重新賦值。

解決方法 

這里將Vuex的數(shù)據(jù)存儲(chǔ)到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) {
  // 離開頁(yè)面 刷新前 將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ù)丟失的問(wèn)題了,實(shí)現(xiàn)了數(shù)據(jù)持久化

VueX數(shù)據(jù)持久化和輔助函數(shù)的使用

1.數(shù)據(jù)持久化

1.1本地緩存

在項(xiàng)目中使用vuex進(jìn)行項(xiàng)目一些公共狀態(tài)的共享,可以在任意頁(yè)面中使用,避免了數(shù)據(jù)在組件中層層傳遞的繁瑣。而且vuex中的數(shù)據(jù)是響應(yīng)式的,很好的幫助我們解決了這個(gè)問(wèn)題。但是vuex中的數(shù)據(jù)是保存在內(nèi)存中的,頁(yè)面刷新會(huì)重新初始化導(dǎo)致數(shù)據(jù)丟失。

我們可以使用localStorage或者sessionStorage,在mutation更改數(shù)據(jù)的時(shí)候,同時(shí)往瀏覽器本地緩存也存一份,在state取的時(shí)候也從本地緩存取一份或者用原來(lái)的。

1.2 使用第三方庫(kù) vuex-persistedstate

npm install --save?vuex-persistedstate

使用vuex-persistedstate默認(rèn)存儲(chǔ)到localStorage

 引入之后,配置plugins和存儲(chǔ)持久化的鍵名即可,就會(huì)自動(dòng)在localStorage配置的鍵名下存儲(chǔ)state全局?jǐn)?shù)據(jù)和模塊化之后的數(shù)據(jù)

2.Vuex輔助函數(shù)的使用 

vuex可以使用$store.state或者getters,$store.dispatch和commit觸發(fā)actions和mutations更新。也可以使用輔助函數(shù)。

$store的寫法最簡(jiǎn)單且通俗易懂,但輔助函數(shù)的寫法也建議大家掌握,免得遇到有些項(xiàng)目中遇到了看不懂。

首先需要從vuex中引入輔助函數(shù)

2.1 mapState和getters

mapState可以使用數(shù)組語(yǔ)法也可以使用,對(duì)象語(yǔ)法。

當(dāng)vuex沒(méi)有模塊化的時(shí)候,可以直接使用數(shù)組語(yǔ)法,簡(jiǎn)單便捷,...mapState['state中鍵名'];也可以使用對(duì)象語(yǔ)法,如下。模塊化之后也有兩是寫法,數(shù)組:...mapState['模塊名','鍵名'];對(duì)象:如下。getters也是兩種寫法,和state一樣,都是寫在計(jì)算屬性中。

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ù)組和對(duì)象寫法。

以mapMutations為例,數(shù)組:...mapMutations('模塊名',['鍵名'])

對(duì)象:...mapMutations({自定義鍵名:"模塊名/鍵名"})

methods: {
			// ...mapMutations('bill',['SET_AMOUNT']),
			...mapMutations({
				SET_AMOUNT: "bill/SET_AMOUNT"
			}),
			...mapActions('bill', ['FETCH_AMOUNT']),
		},

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue使用tracking實(shí)現(xiàn)人臉識(shí)別/人臉偵測(cè)完整代碼

    vue使用tracking實(shí)現(xiàn)人臉識(shí)別/人臉偵測(cè)完整代碼

    作為一個(gè)AI模型,人臉識(shí)別涉及到多個(gè)技術(shù)領(lǐng)域,下面這篇文章主要給大家介紹了關(guān)于vue使用tracking實(shí)現(xiàn)人臉識(shí)別/人臉偵測(cè)的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-09-09
  • 十分鐘封裝一個(gè)好用的axios步驟示例

    十分鐘封裝一個(gè)好用的axios步驟示例

    這篇文章主要為大家介紹了十分鐘封裝一個(gè)好用的axios步驟示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • vue項(xiàng)目中如何引入cesium

    vue項(xiàng)目中如何引入cesium

    這篇文章主要介紹了vue項(xiàng)目中如何引入cesium問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue-element-admin登錄全流程分享

    vue-element-admin登錄全流程分享

    這篇文章主要介紹了vue-element-admin登錄全流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue結(jié)合Echarts實(shí)現(xiàn)點(diǎn)擊高亮效果的示例

    vue結(jié)合Echarts實(shí)現(xiàn)點(diǎn)擊高亮效果的示例

    下面小編就為大家分享一篇vue結(jié)合Echarts實(shí)現(xiàn)點(diǎn)擊高亮效果的示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • 如何在vue中使用pdfjs預(yù)覽pdf文件

    如何在vue中使用pdfjs預(yù)覽pdf文件

    本文主要講解了如何在vue中使用pdfjs預(yù)覽pdf文件,這樣的優(yōu)勢(shì)是無(wú)須讓用戶安裝專門的軟件即可實(shí)現(xiàn)預(yù)覽,下面就看看如何實(shí)現(xiàn)這個(gè)需求
    2021-06-06
  • ant design vue 清空upload組件圖片緩存的問(wèn)題

    ant design vue 清空upload組件圖片緩存的問(wèn)題

    這篇文章主要介紹了ant design vue 清空upload組件圖片緩存的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • vue中v-for和v-if一起使用之使用compute的示例代碼

    vue中v-for和v-if一起使用之使用compute的示例代碼

    這篇文章主要介紹了vue中v-for和v-if一起使用之使用compute的相關(guān)知識(shí),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • Vue?axios和vue-axios的關(guān)系及使用區(qū)別

    Vue?axios和vue-axios的關(guān)系及使用區(qū)別

    axios是基于promise的HTTP庫(kù),可以使用在瀏覽器和node.js中,它不是vue的第三方插件,vue-axios是axios集成到Vue.js的小包裝器,可以像插件一樣安裝使用:Vue.use(VueAxios, axios),本文給大家介紹Vue?axios和vue-axios關(guān)系,感興趣的朋友一起看看吧
    2022-08-08
  • Vue3和Vue2的slot-scope插槽用法解讀

    Vue3和Vue2的slot-scope插槽用法解讀

    這篇文章主要介紹了Vue3和Vue2的slot-scope插槽用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10

最新評(píng)論