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

vue中keep-alive的使用及說明

 更新時間:2025年05月15日 10:09:40   作者:愛編程的小學(xué)究  
這篇文章主要介紹了vue中keep-alive的使用及說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

原理

我們知道vue是通過vnode實(shí)現(xiàn)保存節(jié)點(diǎn)的,而keep-alive本身也是通過保存vnode來實(shí)現(xiàn)緩存的,而不是直接存儲DOM結(jié)構(gòu)。其實(shí)就是將需要緩存的VNode節(jié)點(diǎn)保存在this.cache中,在render時,如果VNode的name符合在緩存條件(可以用include以及exclude控制),則會從this.cache中取出之前緩存的VNode實(shí)例進(jìn)行渲染

作用

keep-alive組件是vue2.0提供的一個緩存組件,在組件切換過程中把切換出去的組件保留在內(nèi)存中,防止重復(fù)渲染DOM,減少加載時間及性能消耗,提高用戶體驗(yàn)性

效果

keep-alive組件,只要將子組件嵌套在這里面就可以實(shí)現(xiàn)組件的緩存,當(dāng)頁面返回時數(shù)據(jù)不會丟失,實(shí)現(xiàn)了我們常見的歷史頁面不刷新的效果

參數(shù)Props

  • include - 類型字符串、數(shù)組以及正則表達(dá)式,只有匹配的組件會被緩存
  • exclude - 類型字符串、數(shù)組以及正則表達(dá)式,匹配的組件不會被緩存
  • max - 類型字符或者數(shù)字,可以控制緩存組件的個數(shù),緩存組件的最大值
// 只緩存組件name為a或者b的組件
<keep-alive include="a,b"> 
  <component />
</keep-alive>
?
// 組件name為c的組件不緩存(可以保留它的狀態(tài)或避免重新渲染)
<keep-alive exclude="c"> 
  <component />
</keep-alive>
?
// 如果同時使用include,exclude,那么exclude優(yōu)先于include, 下面的例子只緩存a組件
<keep-alive include="a,b" exclude="b"> 
  <component />
</keep-alive>
?
// 如果緩存的組件超過了max設(shè)定的值5,那么將刪除第一個緩存的組件
<keep-alive exclude="c" max="5"> 
  <component />
</keep-alive>

生命周期的變化

1.activated

  • 在 keep-alive 組件激活時調(diào)用
  • 該鉤子函數(shù)在服務(wù)器端渲染期間不被調(diào)用
  • 使用 keep-alive 會將數(shù)據(jù)保留在內(nèi)存中,如果要在每次進(jìn)入頁面的時候獲取最新的數(shù)據(jù),需要在 activated 階段獲取數(shù)據(jù),承擔(dān)原來 created 鉤子函數(shù)中獲取數(shù)據(jù)的任務(wù)。
activated(){
    /** 
     * 緩存的組件點(diǎn)擊時調(diào)用
    */
  },

2.deactivated

  • 在 keep-alive 組件停用時調(diào)用
  • 該鉤子函數(shù)在服務(wù)器端渲染期間不被調(diào)用
  • 被包含在 keep-alive 中創(chuàng)建的組件,會多出兩個生命周期的鉤子: activated 與 deactivated
deactivated(){
    /** 
     * 緩存的組件點(diǎn)擊時調(diào)用
    */
  },

小知識點(diǎn):

1、同時使用include,exclude,那么exclude優(yōu)先于include

2、緩存的組件超過了max設(shè)定的值5,那么將刪除第一個緩存的組件

3、keep-alive 不會在函數(shù)式組件中正常工作,因?yàn)樗鼈儧]有緩存實(shí)例

4、keep-alive 先匹配被包含組件的 name 字段,如果 name 不可用,則匹配當(dāng)前組件 components 配置中的注冊名稱

5、只有組件被 keep-alive 包裹時,這兩個生命周期函數(shù)才會被調(diào)用,如果作為正常組件使用,是不會被調(diào)用的,以及在 2.1.0 版本之后,包含在 keep-alive 中,但符合 exclude ,不會調(diào)用activated和 deactivated這兩個函數(shù)鉤子!另外,在服務(wù)端渲染時,此鉤子函數(shù)也不會被調(diào)用

用法

1.與include結(jié)合使用

// include 只緩存組件名字為home的組件,其他組件不會緩存,而exclude恰好相反
<keep-alive include="home">
   <router-view />
</keep-alive>

2.結(jié)合Router中的meta屬性來控制組件緩存

{
      path: '/',
      name: 'home',
      meta:{
        keepAlive:true // 需要緩存
      },
      component: Home,
      children: [
        {
          path: 'goods',
          name: 'goods',
          component: Goods,
          meta: {
        	keepAlive: false // 不需要緩存
      	  }
        }
      ]
    }
<keep-alive>
    <router-view v-if="$route.meta.keepAlive" />
</keep-alive>
<router-view v-if="!$route.meta.keepAlive" />

緩存所有頁面:

在app.vue頁面里加keep-alive

緩存部分頁面:

1、在app.vue頁面里加keep-alive,結(jié)合keep-alive的include屬性

2、結(jié)合Router中的meta屬性,在app.vue頁面里加$route.meta.keepAlive的if判斷

總結(jié)

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文教你如何在Vue項(xiàng)目中使用Emoji表情

    一文教你如何在Vue項(xiàng)目中使用Emoji表情

    這篇文章主要為大家詳細(xì)介紹了在vue項(xiàng)目中如何使用emoji表情,包括font-awesome圖標(biāo),v-emoji-picker,vue-emoji等emoji表情庫,需要的可以參考下
    2025-03-03
  • vue插件實(shí)現(xiàn)v-model功能

    vue插件實(shí)現(xiàn)v-model功能

    最近在開發(fā)自己的富文本編輯器插件,在開發(fā)中遇到了很多問題其中我覺得比較好的問題就是在你定義的插件中實(shí)現(xiàn)雙向綁定。這篇文章主要介紹了vue插件實(shí)現(xiàn)v-model功能,需要的朋友可以參考下
    2018-09-09
  • vue仿攜程輪播圖效果(滑動輪播,下方高度自適應(yīng))

    vue仿攜程輪播圖效果(滑動輪播,下方高度自適應(yīng))

    這篇文章主要介紹了vue仿攜程輪播圖效果(滑動輪播,下方高度自適應(yīng)),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-02-02
  • Vue.js通過組件處理Icon圖標(biāo)

    Vue.js通過組件處理Icon圖標(biāo)

    這篇文章介紹了Vue.js通過組件處理Icon圖標(biāo)的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-11-11
  • vue3.0報(bào)錯Cannot?find?module‘worker_threads‘的解決辦法

    vue3.0報(bào)錯Cannot?find?module‘worker_threads‘的解決辦法

    這篇文章介紹了vue3.0報(bào)錯Cannot?find?module‘worker_threads‘的解決辦法。對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-11-11
  • vue實(shí)現(xiàn)背景圖片鋪滿整個屏幕(適配所有機(jī)型)

    vue實(shí)現(xiàn)背景圖片鋪滿整個屏幕(適配所有機(jī)型)

    在網(wǎng)頁設(shè)計(jì)中,背景全屏是一種常見的視覺效果,通過正確的CSS樣式設(shè)置,可以實(shí)現(xiàn)背景全屏且內(nèi)容在固定一屏大小內(nèi)完全顯示,如果內(nèi)容超出一屏,則可以通過滾動條查看剩余內(nèi)容,這種設(shè)計(jì)可以提升用戶的瀏覽體驗(yàn),使網(wǎng)頁看起來更加整潔和專業(yè)
    2024-10-10
  • 詳解.vue文件解析的實(shí)現(xiàn)

    詳解.vue文件解析的實(shí)現(xiàn)

    這篇文章主要介紹了詳解.vue文件解析的實(shí)現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • vue+axios 前端實(shí)現(xiàn)登錄攔截的兩種方式(路由攔截、http攔截)

    vue+axios 前端實(shí)現(xiàn)登錄攔截的兩種方式(路由攔截、http攔截)

    本文通過實(shí)例代碼給大家介紹了vue+axios 前端實(shí)現(xiàn)登錄攔截的方法,主要通過路由攔截和http攔截,具體實(shí)例代碼大家跟隨小編一起通過本文學(xué)習(xí)吧
    2018-10-10
  • vue中如何實(shí)現(xiàn)變量和字符串拼接

    vue中如何實(shí)現(xiàn)變量和字符串拼接

    這篇文章主要介紹了vue中如何實(shí)現(xiàn)變量和字符串拼接,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 詳解Vue中數(shù)據(jù)可視化詞云展示與詞云的生成

    詳解Vue中數(shù)據(jù)可視化詞云展示與詞云的生成

    數(shù)據(jù)可視化是現(xiàn)代Web應(yīng)用程序中的一個重要組成部分,詞云是一種非常流行的數(shù)據(jù)可視化形式,可以用來展示文本數(shù)據(jù)中的主題和關(guān)鍵字,本文我們將介紹如何在Vue中使用詞云庫進(jìn)行數(shù)據(jù)可視化詞云展示和詞云生成,需要的可以參考一下
    2023-06-06

最新評論