久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術(shù)文章
文章詳情頁

解決vue頁面刷新,數(shù)據(jù)丟失的問題

瀏覽:95日期:2022-10-24 10:46:03

在做vue項目的過程中有時候會遇到一個問題,就是進行F5頁面刷新的時候,頁面的數(shù)據(jù)會丟失,出現(xiàn)這個問題的原因是因為當用vuex做全局狀態(tài)管理的時候,store中的數(shù)據(jù)是保存在運行內(nèi)存中的,頁面刷新時會重新加載vue實例,store中的數(shù)據(jù)就會被重新賦值,因此數(shù)據(jù)就丟失了,解決方式如下:

解決方法一:

最先想到的應該就是利用localStorage/sessionStorage將數(shù)據(jù)儲存在外部,做一個持久化儲存,下面是利用localStorage存儲的具體方案:

方案一:由于state中的數(shù)據(jù)是響應式的,而數(shù)據(jù)又是通過mutation來進行修改,故在通過mutation修改state中數(shù)據(jù)的同時調(diào)用localStorage.setItem()方法來進行數(shù)據(jù)的存儲。

import Vue from ’vue’;import Vuex from ’vuex’;Vue.use(Vuex);export default new Vuex.Store({ state: { orderList: [], menuList: [] }, mutations: { orderList(s, d) { s.orderList= d; window.localStorage.setItem('list',JSON.stringify(s.orderList)) }, menuList(s, d) { s.menuList = d; window.localStorage.setItem('list',JSON.stringify(s.menuList)) }, }})

在頁面加載的時候再通過localStorage.getItem()將數(shù)據(jù)取出放回到vuex,可在app.vue的created()周期函數(shù)中寫如下代碼:

if (window.localStorage.getItem('list') ) { this.$store.replaceState(Object.assign({}, this.$store.state,JSON.parse(window.localStorage.getItem('list'))))}

方案二:方案一能夠順利解決問題,但不斷觸發(fā)localStorage.setItem()方法對性能不是特別友好,而且一直將數(shù)據(jù)同步到localStorage中似乎就沒必要再用vuex做狀態(tài)管理,直接用localStorage即可,于是對以上解決方法進行了改進,通過監(jiān)聽beforeunload事件來進行數(shù)據(jù)的localStorage存儲,beforeunload事件在頁面刷新時進行觸發(fā),具體做法是在App.vue的created()周期函數(shù)中下如下代碼:

if (window.localStorage.getItem('list') ) { this.$store.replaceState(Object.assign({}, this.$store.state,JSON.parse(window.localStorage.getItem('list')))) } window.addEventListener('beforeunload',()=>{ window.localStorage.setItem('list',JSON.stringify(this.$store.state)) })

解決方法二(推薦):

這個方法是基于對computed計算屬性的理解,在vue的官方文檔中有這么一段話:

解決vue頁面刷新,數(shù)據(jù)丟失的問題

由此得知計算屬性的結(jié)果會被緩存,也就是說在有緩存的情況下,computed會優(yōu)先使用緩存,于是也可以在state數(shù)據(jù)相對應的頁面這樣寫:

computed:{ orderList() { return this.$store.state.orderList }}

以上就是解決vue頁面刷新,數(shù)據(jù)丟失的問題的詳細內(nèi)容,更多關(guān)于vue頁面刷新,數(shù)據(jù)丟失的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標簽: Vue
主站蜘蛛池模板: 久久久国产一区二区三区 | 一区二区在线视频免费观看 | 精品成人国产 | 久久久久9999国产精品 | 在线观看亚洲免费 | 91精品国产91久久久久久不卡 | 日韩一区二区在线观看 | 国产亚洲一区二区三区在线观看 | 福利视频网 | 我要看免费黄色片 | 亚洲免费在线观看 | av香港经典三级级 在线 | 亚洲一级淫片 | 夜夜天天操 | 在线视频这里只有精品 | 久久久久久久久久久亚洲 | 日韩久久精品 | 精品美女在线 | 黄色av免费看 | 婷婷亚洲综合 | 亚洲国产中文字幕 | 成人免费观看男女羞羞视频 | 99久久久无码国产精品 | 一区二区三区视频 | 日韩成人精品 | 精品伦精品一区二区三区视频 | 91视频分类| 久久久精品视频免费观看 | 国产视频大全 | 人人射av | 一级大毛片 | 日韩国产免费观看 | 一区二区三区国产视频 | 成年人黄色一级毛片 | 日韩av入口| 在线 丝袜 欧美 日韩 制服 | 久久这里只有精品8 | 91视频观看 | 先锋影音av资源站 | 大乳videos巨大吃奶 | 国产免费一区二区 |