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

解決keep-alive同一個組件不緩存問題

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

問題描述

發(fā)現(xiàn)左側(cè)菜單打開的路徑和組件不同時
即如下配置的 User.vueLogin.vue 這兩個頁面時,keep-alive會生效,但是 切換到 /app/1/false就不會進行緩存。
在各組件中的生命周期加上打印信息,包括 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',   // 實際每個菜單的 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
操作:點擊順序
1->2->3->2->3
// 打印如下
created in App.vue
mounted in App.vue
id: 2 // 切換 tab2 時,數(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第一次進入時會觸發(fā) created, 之后每次切換都是走 activated鉤子,其緩存了搜索輸入;
在 tab1->tab2時只根據(jù)路由中的 id信息進行了響應式變化操作,tab3 -> tab2時,又重新渲染了 App.vue組件

解決方案

針對 帶 附帶信息的路由的 name進行統(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)

問題分析/總結(jié)

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

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

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

相關(guān)文章

  • Vue全局自定義指令Modal拖拽的實踐

    Vue全局自定義指令Modal拖拽的實踐

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

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

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

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

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

    vue.js中過濾器的使用教程

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

    vue實現(xiàn)多個tab標簽頁的切換與關(guān)閉詳細代碼

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

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

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

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

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

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

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

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

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

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

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

最新評論