使用keep-alive時(shí),數(shù)據(jù)無(wú)法刷新的問(wèn)題及解決
使用keep-alive時(shí),數(shù)據(jù)無(wú)法刷新問(wèn)題
keep-alive 相關(guān)內(nèi)容
概念: <keep-alive>
是Vue的一個(gè)內(nèi)部組件,適合用來(lái)緩存不需要實(shí)時(shí)更新的組件,這樣可以保留組件狀態(tài)避免重新渲染。
Props:
include
:接受字符串或正則表達(dá)式,這里是需要被緩存的組件名exclude
:接受字符串或正則表達(dá)式,這里是不需要緩存的組件名max
:接受數(shù)字,最多可以緩存多少組件實(shí)例
問(wèn)題:在需要重新請(qǐng)求數(shù)據(jù)的時(shí)候,依然走的緩存
案例中的部分源碼:
問(wèn)題描述:這個(gè)項(xiàng)目是一個(gè)后臺(tái)管理系統(tǒng),由于很多組件都有走緩存的原因,導(dǎo)致在更換賬戶(hù)之后,數(shù)據(jù)依然走的緩存,并沒(méi)有加載新的數(shù)據(jù),從而賬戶(hù)雖然已經(jīng)更換,但是現(xiàn)實(shí)的內(nèi)容還是上一個(gè)賬戶(hù)下的內(nèi)容,這時(shí)候在network也會(huì)發(fā)現(xiàn),除了之前請(qǐng)求的數(shù)據(jù),就沒(méi)有新數(shù)據(jù)請(qǐng)求的記錄了
解決方案:
方案1: 如果要在進(jìn)入頁(yè)面的時(shí)候獲取最新的數(shù)據(jù),需要在activated階段獲取數(shù)據(jù),承擔(dān)原來(lái)created鉤子中獲取數(shù)據(jù)的任務(wù)(親測(cè),時(shí)而有效,時(shí)而無(wú)效,不知道是什么原因)。
方案2: 在賬戶(hù)登錄之后調(diào)用 **window.location.reload() **,起到重新請(qǐng)求的作用(已親測(cè))
方案3: 在vuex中設(shè)置狀態(tài),動(dòng)態(tài)綁定 include 值,在登錄的時(shí)候緩存需要緩存的組件,在退出的時(shí)候,清除需要刷新的組件(效果很理想,也順帶解決了加載數(shù)據(jù)時(shí),數(shù)據(jù)閃現(xiàn)的情況)
//--------------------- VUEX ---------------------------- const state = { keepAliveList: 'login,index,productionList,characterList,dynamicList,QAList,fansList'// 需要緩存的頁(yè)面 } const mutations = { KeepAliveListState (state) { state.keepAliveList = 'login,index,productionList,characterList,dynamicList,QAList,fansList' }, removeAliveList (state) { state.keepAliveList = 'index' } } const getters = { keepAliveListState (state) { return state.keepAliveList } } export default new Vuex.Store({ state, mutations, getters })
//--------------------- 在app中統(tǒng)一監(jiān)控---------------- computed: { keepAliveList () { if (this.$store.getters.keepAliveListState) { return this.$store.getters.keepAliveListState } } }, //--------------------- 在退出的時(shí)候,提交removeAliveList --------------- this.$store.commit('removeAliveList') //--------------------- 在登錄的時(shí)候,提交KeepAliveListState --------------- this.$store.commit('KeepAliveListState')
keep-alive數(shù)據(jù)刷新問(wèn)題
有時(shí)候?qū)崟r(shí)數(shù)據(jù)需要刷新但由于緩存會(huì)顯示之前的數(shù)據(jù) 用戶(hù)點(diǎn)擊之后會(huì)報(bào)錯(cuò):
處理方式如下
(1)在vuex中設(shè)置狀態(tài),動(dòng)態(tài)綁定 include 值,在登錄的時(shí)候緩存需要緩存的組件,在退出的時(shí)候,清除需要刷新的組件(效果很理想,也順帶解決了加載數(shù)據(jù)時(shí),數(shù)據(jù)閃現(xiàn)的情況) 或者exclude寫(xiě)入不緩存的
(2)放在actived中獲取數(shù)據(jù)
(3)
tips:
beforeRouteEnter --> created --> mounted --> activated --> deactivated
再次進(jìn)入緩存的頁(yè)面,只會(huì)觸發(fā)beforeRouteEnter -->activated --> deactivated 。created和mounted不會(huì)再執(zhí)行。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vscode配置@路徑提示方式,并解決vue文件內(nèi)失效的問(wèn)題
這篇文章主要介紹了vscode配置@路徑提示方式,并解決vue文件內(nèi)失效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10vue3實(shí)現(xiàn)動(dòng)態(tài)路由及菜單
這篇文章主要介紹了vue3實(shí)現(xiàn)動(dòng)態(tài)路由及菜單,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03vuecli4插件svg-sprite-loader使用svg圖標(biāo)
這篇文章主要為大家介紹了vuecli4插件svg-sprite-loader使用svg圖標(biāo)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08vue.js+Echarts開(kāi)發(fā)圖表放大縮小功能實(shí)例
本篇文章主要介紹了vue.js+Echarts開(kāi)發(fā)圖表放大縮小功能實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式(query、params)
這篇文章主要介紹了Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式,本文主要通過(guò)query方式和params方式介紹,需要的朋友可以參考下2019-12-12vue計(jì)算屬性+vue中class與style綁定(推薦)
這篇文章主要介紹了vue計(jì)算屬性+vue中class與style綁定,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-03-03Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值)
這篇文章主要介紹了Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11