91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

vue怎么自定義keepalive組件

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

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

為什么會出現這種情況呢

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

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

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

vue怎么自定義keepalive組件

vue怎么自定義keepalive組件

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

如何解決這個問題呢

這個比較簡單之前是因為組件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一定要區分
computed: {
    key() {
      return `${選中index}/${fullpath}`
    },
}

主題說完了,整點其他的

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

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

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

向AI問一下細節

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

AI

当阳市| 沁阳市| 黑河市| 辽宁省| 乾安县| 梅河口市| 克东县| 张家口市| 团风县| 霍州市| 盈江县| 开封县| 应用必备| 黔江区| 房产| 陆丰市| 华阴市| 呼玛县| 林州市| 巫山县| 合作市| 博乐市| 沭阳县| 五常市| 石林| 新源县| 沾益县| 祁东县| 梁平县| 邻水| 金湖县| 永宁县| 慈利县| 平谷区| 安顺市| 即墨市| 高雄县| 新野县| 剑河县| 沙河市| 凤阳县|