您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“vue怎么自定義keepalive組件”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“vue怎么自定義keepalive組件”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
keep-alive
組件是使用include
exclude
這兩個屬性傳入組件名稱來確認哪些可以被緩存的
<keep-alive exclude="a,b,c" > <router-view></router-view> </keep-alive>
我們在看一下源碼,看看人家是怎么實現(xiàn)的(這兩張圖截的真難看)
主要邏輯(直說上述代碼)就是根據(jù)傳入的
include
,exclude
兩個屬性傳入數(shù)組,根據(jù)當前訪問的組件名稱判斷。我們相同鏈接都訪問同一個組件名稱(name)相同,第二次訪問的時候,鏈接指向的是同一個組件,因為使用組件的name作為緩存key,此時會被認為是讀取緩存操作,就會直接加載緩存并渲染,所以出現(xiàn)了兩個tab頁訪問同一個鏈接,出現(xiàn)聯(lián)動情況
這個比較簡單之前是因為組件name當key導致的,那我們就不使用組件的name作為key了,改為name+tab的index作為key。
group-keep-alive.js
意思一下就行了
<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è)資訊頻道。
免責聲明:本站發(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)容。