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

使用keep-alive時(shí),數(shù)據(jù)無(wú)法刷新的問(wèn)題及解決

 更新時(shí)間:2023年07月04日 10:13:17   作者:碎碎。  
這篇文章主要介紹了使用keep-alive時(shí),數(shù)據(jù)無(wú)法刷新的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

使用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)題

    這篇文章主要介紹了vscode配置@路徑提示方式,并解決vue文件內(nèi)失效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue3實(shí)現(xiàn)動(dòng)態(tài)路由及菜單

    vue3實(shí)現(xiàn)動(dòng)態(tài)路由及菜單

    這篇文章主要介紹了vue3實(shí)現(xiàn)動(dòng)態(tài)路由及菜單,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue-cli設(shè)置publicPath小記

    vue-cli設(shè)置publicPath小記

    這篇文章主要介紹了vue-cli設(shè)置publicPath小記,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • vuecli4插件svg-sprite-loader使用svg圖標(biāo)

    vuecli4插件svg-sprite-loader使用svg圖標(biāo)

    這篇文章主要為大家介紹了vuecli4插件svg-sprite-loader使用svg圖標(biāo)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • vue.js+Echarts開(kāi)發(fā)圖表放大縮小功能實(shí)例

    vue.js+Echarts開(kāi)發(fā)圖表放大縮小功能實(shí)例

    本篇文章主要介紹了vue.js+Echarts開(kāi)發(fā)圖表放大縮小功能實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式(query、params)

    Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式(query、params)

    這篇文章主要介紹了Vue 路由間跳轉(zhuǎn)和新開(kāi)窗口的方式,本文主要通過(guò)query方式和params方式介紹,需要的朋友可以參考下
    2019-12-12
  • vue計(jì)算屬性+vue中class與style綁定(推薦)

    vue計(jì)算屬性+vue中class與style綁定(推薦)

    這篇文章主要介紹了vue計(jì)算屬性+vue中class與style綁定,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • vue如何將字符串變?yōu)閿?shù)組

    vue如何將字符串變?yōu)閿?shù)組

    這篇文章主要介紹了vue如何將字符串變?yōu)閿?shù)組問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值)

    Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值)

    這篇文章主要介紹了Nuxt 嵌套路由nuxt-child組件用法(父子頁(yè)面組件的傳值),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • vue vant Area組件使用詳解

    vue vant Area組件使用詳解

    這篇文章主要介紹了vue vant Area組件使用詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12

最新評(píng)論