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

解決keep-alive同一個(gè)組件不緩存問(wèn)題

 更新時(shí)間:2024年02月11日 11:00:09   作者:_jeneen  
這篇文章給大家介紹了如何解決keep-alive同一個(gè)組件不緩存問(wèn)題,文中通過(guò)代碼示例給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下

問(wèn)題描述

發(fā)現(xiàn)左側(cè)菜單打開的路徑和組件不同時(shí)
即如下配置的 User.vueLogin.vue 這兩個(gè)頁(yè)面時(shí),keep-alive會(huì)生效,但是 切換到 /app/1/false就不會(huì)進(jìn)行緩存。
在各組件中的生命周期加上打印信息,包括 activated, deactivated。

// 路由配置
{  // tab3
  path: '/user',
  name: 'User',
  component: () => import('../User.vue'),
},
{
  path: '/',
  name: 'Login',
  component: () => import('../Login.vue'),
},
{ // tab1, tab2
  path: '/app/:id/:single',
  name: 'App',   // 實(shí)際每個(gè)菜單的 name  和 path 一樣
  component: () => import('../App.vue'),
},

// 綠色框組件中
<transition name="fade-transform" mode="out-in">
    <el-main>
      <keep-alive :include="cachedTags">
        <router-view :key="key" />
      </keep-alive>
    </el-main>
  </transition>

get cachedTags() {
    return TagsViewModule.cachedTags  即 // 菜單的 name 的組合
  }

  get key() {
    return this.$route.path
}
菜單namepath
tab1/app/1/false/app/1/false
tab2/app/2/false/app/2/false
tab3/user/user
操作:點(diǎn)擊順序
1->2->3->2->3
// 打印如下
created in App.vue
mounted in App.vue
id: 2 // 切換 tab2 時(shí),數(shù)據(jù)發(fā)生變化
created in User.vue // 切換 tab3 
mounted in User.vue
activated in User.vue
created in App.vue  // 切換 tab2 
deactivated in User.vue  
mounted in App.vue
activated in User.vue  // 切換 tab3

// cachedTags : [ '/user',  '/app/1/false',  '/app/2/true' ]

tab3第一次進(jìn)入時(shí)會(huì)觸發(fā) created, 之后每次切換都是走 activated鉤子,其緩存了搜索輸入;
在 tab1->tab2時(shí)只根據(jù)路由中的 id信息進(jìn)行了響應(yīng)式變化操作,tab3 -> tab2時(shí),又重新渲染了 App.vue組件

解決方案

針對(duì) 帶 附帶信息的路由的 name進(jìn)行統(tǒng)一處理。

// 處理后 cachedTags : [ 'User', 'App' ]
const viewName = this.$route.name
if (view.name.startsWith('app/')) {
  viewName = 'App'  // 注意要與 App.vue 組件里的 name 一致
}
// 緩存依據(jù)于 router name
if (viewName === null) return
if (this.cachedTags.includes(viewName)) return
this.cachedTags.push(viewName)

問(wèn)題分析/總結(jié)

看到這個(gè)解決辦法,應(yīng)該考慮就是 keep-alive對(duì) includes中的哪些才能生效的問(wèn)題?
找到 keep-alive源碼查看( .\node_modules\vue\src\core\components\keep-alive.js)

即要 includes內(nèi)的數(shù)據(jù)和組件的 name配置對(duì)比進(jìn)行的緩存的操作。

到此這篇關(guān)于解決keep-alive同一個(gè)組件不緩存問(wèn)題的文章就介紹到這了,更多相關(guān)keep-alive同一個(gè)組件不緩存內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue全局自定義指令Modal拖拽的實(shí)踐

    Vue全局自定義指令Modal拖拽的實(shí)踐

    最近一直在做的項(xiàng)目是Vue2搭建的項(xiàng)目,本文主要介紹了Vue全局自定義指令Modal拖拽的實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Vue2 添加數(shù)據(jù)可視化支持的方法步驟

    Vue2 添加數(shù)據(jù)可視化支持的方法步驟

    這篇文章主要介紹了Vue2 添加數(shù)據(jù)可視化支持的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • VUE 更好的 ajax 上傳處理 axios.js實(shí)現(xiàn)代碼

    VUE 更好的 ajax 上傳處理 axios.js實(shí)現(xiàn)代碼

    本篇文章主要介紹了VUE 更好的 ajax 上傳處理 axios.js實(shí)現(xiàn)代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • vue.js中過(guò)濾器的使用教程

    vue.js中過(guò)濾器的使用教程

    過(guò)濾器是一個(gè)通過(guò)輸入數(shù)據(jù),能夠及時(shí)對(duì)數(shù)據(jù)進(jìn)行處理并返回一個(gè)數(shù)據(jù)結(jié)果的簡(jiǎn)單函數(shù)。下面這篇文章主要給大家介紹了關(guān)于vue.js中過(guò)濾器使用的相關(guān)資料,需要的朋友可以參考借鑒,下面來(lái)看看詳細(xì)的介紹。
    2017-06-06
  • vue實(shí)現(xiàn)多個(gè)tab標(biāo)簽頁(yè)的切換與關(guān)閉詳細(xì)代碼

    vue實(shí)現(xiàn)多個(gè)tab標(biāo)簽頁(yè)的切換與關(guān)閉詳細(xì)代碼

    這篇文章主要給大家介紹了關(guān)于vue實(shí)現(xiàn)多個(gè)tab標(biāo)簽頁(yè)的切換與關(guān)閉的相關(guān)資料,使用vue.js實(shí)現(xiàn)tab切換很簡(jiǎn)單,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-10-10
  • javaScript與vue獲取元素的方法代碼示例

    javaScript與vue獲取元素的方法代碼示例

    在開發(fā)中我們可能會(huì)遇到這樣的問(wèn)題,文本框聚焦、元素點(diǎn)擊等,所以下面這篇文章主要給大家介紹了關(guān)于javaScript與vue獲取元素的相關(guān)資料,需要的朋友可以參考下
    2023-10-10
  • Vue 3中的異步操作管理示例分析

    Vue 3中的異步操作管理示例分析

    在現(xiàn)代Web應(yīng)用開發(fā)中,異步操作是常見的挑戰(zhàn),本文介紹了Vue3中管理多個(gè)異步操作的方法,幫助開發(fā)者提高編碼效率和應(yīng)用性能,感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • 如何實(shí)現(xiàn)echarts markline標(biāo)簽名顯示自己想要的

    如何實(shí)現(xiàn)echarts markline標(biāo)簽名顯示自己想要的

    這篇文章主要介紹了實(shí)現(xiàn)echarts markline標(biāo)簽名顯示自己想要的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • Vue.js中自定義Markdown插件實(shí)現(xiàn)References解析(推薦)

    Vue.js中自定義Markdown插件實(shí)現(xiàn)References解析(推薦)

    本文主要寫的是,如何編寫一個(gè)插件來(lái)解析<references>標(biāo)簽,并將其轉(zhuǎn)換為HTML,這種方法可以應(yīng)用于其他自定義標(biāo)簽和功能,為Vue.js應(yīng)用程序中的Markdown渲染提供了極大的靈活性,感興趣的朋友跟隨小編一起看看吧
    2024-07-07
  • Vue使用Echarts實(shí)現(xiàn)排行榜效果

    Vue使用Echarts實(shí)現(xiàn)排行榜效果

    這篇文章主要為大家詳細(xì)介紹了Vue使用Echarts實(shí)現(xiàn)排行榜效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評(píng)論