溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue怎么自定義keepalive組件

發(fā)布時間:2022-09-20 14:50:58 來源:億速云 閱讀:121 作者:iii 欄目:開發(fā)技術(shù)

本文小編為大家詳細介紹“vue怎么自定義keepalive組件”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“vue怎么自定義keepalive組件”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

為什么會出現(xiàn)這種情況呢

keep-alive組件是使用 include exclude這兩個屬性傳入組件名稱來確認哪些可以被緩存的

    <keep-alive exclude="a,b,c" >
        <router-view></router-view>
    </keep-alive>

我們在看一下源碼,看看人家是怎么實現(xiàn)的(這兩張圖截的真難看)

vue怎么自定義keepalive組件

vue怎么自定義keepalive組件

主要邏輯(直說上述代碼)就是根據(jù)傳入的 include, exclude 兩個屬性傳入數(shù)組,根據(jù)當前訪問的組件名稱判斷。我們相同鏈接都訪問同一個組件名稱(name)相同,第二次訪問的時候,鏈接指向的是同一個組件,因為使用組件的name作為緩存key,此時會被認為是讀取緩存操作,就會直接加載緩存并渲染,所以出現(xiàn)了兩個tab頁訪問同一個鏈接,出現(xiàn)聯(lián)動情況

如何解決這個問題呢

這個比較簡單之前是因為組件name當key導致的,那我們就不使用組件的name作為key了,改為name+tab的index作為key。

問題知道了怎么解決呢

vue怎么自定義keepalive組件

思路有了擼代碼

group-keep-alive.js

vue怎么自定義keepalive組件

如何使用

意思一下就行了

<group-keep-alive>
   <router-view :key="key" />
/group-keep-alive>

// key一定要區(qū)分
computed: {
    key() {
      return `${選中index}/${fullpath}`
    },
}

主題說完了,整點其他的

1. 在group-keep-alive組件中設置了abstract: true,設置當前組件為抽象組件,我的李姐:就是一個對下一級(包含子元素)事件監(jiān)聽等提前攔截,從而對下一級進行操作

2. router-view :key="key" 這key的作用是用來區(qū)分同一個組件是不是重復使用一個實例。

讀到這里,這篇“vue怎么自定義keepalive組件”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI