欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vuex頁(yè)面刷新數(shù)據(jù)丟失解決方法詳解

 更新時(shí)間:2023年07月14日 09:35:09   作者:醉前端  
這篇文章主要為大家介紹了vuex頁(yè)面刷新數(shù)據(jù)丟失解決方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

原因

在vue項(xiàng)目中用vuex來(lái)做全局的狀態(tài)管理, 發(fā)現(xiàn)當(dāng)刷新網(wǎng)頁(yè)后,保存在vuex實(shí)例store里的數(shù)據(jù)會(huì)丟失。

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

解決思路

將state的數(shù)據(jù)保存在localstorage、sessionstorage或cookie中(三者的區(qū)別),這樣即可保證頁(yè)面刷新數(shù)據(jù)不丟失且易于讀取。

  • localStorage: localStorage的生命周期是永久的,關(guān)閉頁(yè)面或?yàn)g覽器之后localStorage中的數(shù)據(jù)也不會(huì)消失。localStorage除非主動(dòng)刪除數(shù)據(jù),否則數(shù)據(jù)永遠(yuǎn)不會(huì)消失。
  • sessionStorage:sessionStorage的生命周期是在僅在當(dāng)前會(huì)話下有效。sessionStorage引入了一個(gè)“瀏覽器窗口”的概念,sessionStorage是在同源的窗口中始終存在的數(shù)據(jù)。只要這個(gè)瀏覽器窗口沒(méi)有關(guān)閉,即使刷新頁(yè)面或者進(jìn)入同源另一個(gè)頁(yè)面,數(shù)據(jù)依然存在。但是sessionStorage在關(guān)閉了瀏覽器窗口后就會(huì)被銷毀。同時(shí)獨(dú)立的打開(kāi)同一個(gè)窗口同一個(gè)頁(yè)面,sessionStorage也是不一樣的。
  • cookie:cookie生命期為只在設(shè)置的cookie過(guò)期時(shí)間之前一直有效,即使窗口或?yàn)g覽器關(guān)閉。 存放數(shù)據(jù)大小為4K左右,有個(gè)數(shù)限制(各瀏覽器不同),一般不能超過(guò)20個(gè)。缺點(diǎn)是不能儲(chǔ)存大數(shù)據(jù)且不易讀取。

由于vue是單頁(yè)面應(yīng)用,操作都是在一個(gè)頁(yè)面跳轉(zhuǎn)路由,因此sessionStorage較為合適,原因如下:

  • sessionStorage可以保證打開(kāi)頁(yè)面時(shí)sessionStorage的數(shù)據(jù)為空;
  • 每次打開(kāi)頁(yè)面localStorage存儲(chǔ)著上一次打開(kāi)頁(yè)面的數(shù)據(jù),因此需要清空之前的數(shù)據(jù)。

vuex中state數(shù)據(jù)的修改必須通過(guò)mutation方法進(jìn)行修改,因此mutation修改state的同時(shí)需要修改sessionstorage,問(wèn)題倒是可以解決但是感覺(jué)很麻煩,state中有很多數(shù)據(jù),很多mutation修改state就要很多次sessionstorage進(jìn)行修改,既然如此直接用sessionstorage解決不就行了,為何還要用vuex多此一舉呢?
vuex的數(shù)據(jù)在每次頁(yè)面刷新時(shí)丟失,是否可以在頁(yè)面刷新前再將數(shù)據(jù)存儲(chǔ)到sessionstorage中呢,是可以的,beforeunload事件可以在頁(yè)面刷新前觸發(fā),但是在每個(gè)頁(yè)面中監(jiān)聽(tīng)beforeunload事件感覺(jué)也不太合適,那么最好的監(jiān)聽(tīng)該事件的地方就在app.vue中。

  • 在app.vue的created方法中讀取sessionstorage中的數(shù)據(jù)存儲(chǔ)在store中,此時(shí)用vuex.store的replaceState方法,替換store的根狀態(tài)
  • 在beforeunload方法中將store.state存儲(chǔ)到sessionstorage中。

代碼如下

export default {
  name: 'App',
  created () {
    //在頁(yè)面加載時(shí)讀取sessionStorage里的狀態(tài)信息
    if (sessionStorage.getItem("store") ) {
        this.$store.replaceState(Object.assign({}, this.$store.state,JSON.parse(sessionStorage.getItem("store"))))
    } 
    //在頁(yè)面刷新時(shí)將vuex里的信息保存到sessionStorage里
    window.addEventListener("beforeunload",()=>{
        sessionStorage.setItem("store",JSON.stringify(this.$store.state))
    })
  }
}

以上就是vuex頁(yè)面刷新數(shù)據(jù)丟失解決方法詳解的詳細(xì)內(nèi)容,更多關(guān)于vuex頁(yè)面刷新數(shù)據(jù)丟失解決的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue Element UI 表單自定義校驗(yàn)規(guī)則及使用

    Vue Element UI 表單自定義校驗(yàn)規(guī)則及使用

    這篇文章主要介紹了Vue Element UI 表單自定義效驗(yàn)規(guī)則及使用,文中通過(guò)代碼介紹了常見(jiàn)表單效驗(yàn)規(guī)則,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-02-02
  • vue中@click如何綁定多個(gè)事件

    vue中@click如何綁定多個(gè)事件

    這篇文章主要介紹了vue中@click如何綁定多個(gè)事件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue如何給數(shù)組添加新對(duì)象并賦值

    vue如何給數(shù)組添加新對(duì)象并賦值

    這篇文章主要介紹了vue如何給數(shù)組添加新對(duì)象并賦值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue3中的reactive函數(shù)聲明數(shù)組方式

    vue3中的reactive函數(shù)聲明數(shù)組方式

    這篇文章主要介紹了vue3中的reactive函數(shù)聲明數(shù)組方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue+TailWindcss實(shí)現(xiàn)一個(gè)簡(jiǎn)單的闖關(guān)小游戲

    Vue+TailWindcss實(shí)現(xiàn)一個(gè)簡(jiǎn)單的闖關(guān)小游戲

    本文將利用Vue+TailWindcss實(shí)現(xiàn)一個(gè)簡(jiǎn)單的闖關(guān)小游戲,玩家須躲避敵人與陷阱到達(dá)終點(diǎn)且擁有多個(gè)關(guān)卡,感興趣的小伙伴可以了解一下
    2022-04-04
  • vue-router 學(xué)習(xí)快速入門(mén)

    vue-router 學(xué)習(xí)快速入門(mén)

    本篇文章主要介紹了vue-router 學(xué)習(xí)快速入門(mén),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • VUE前后端學(xué)習(xí)tab寫(xiě)法實(shí)例

    VUE前后端學(xué)習(xí)tab寫(xiě)法實(shí)例

    在本篇文章里小編給大家分享了關(guān)于VUE前后端學(xué)習(xí)tab寫(xiě)法實(shí)例以及相關(guān)知識(shí)點(diǎn),需要的朋友們參考下。
    2019-08-08
  • vue?elementui動(dòng)態(tài)添加el-input實(shí)例代碼

    vue?elementui動(dòng)態(tài)添加el-input實(shí)例代碼

    最近遇到一個(gè)新的需求,需要?jiǎng)討B(tài)添加el-input,這篇文章主要給大家介紹了關(guān)于vue?elementui動(dòng)態(tài)添加el-input的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-06-06
  • 解決v-model雙向綁定失效的問(wèn)題

    解決v-model雙向綁定失效的問(wèn)題

    這篇文章主要介紹了解決v-model雙向綁定失效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue?組件通信的多種方式

    vue?組件通信的多種方式

    這篇文章主要介紹了vue?組件通信的幾種方式,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03

最新評(píng)論