溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Vue項(xiàng)目中的keepAlive怎么使用

發(fā)布時(shí)間:2022-04-15 17:25:12 來(lái)源:億速云 閱讀:120 作者:zzz 欄目:開(kāi)發(fā)技術(shù)

這篇“Vue項(xiàng)目中的keepAlive怎么使用”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“Vue項(xiàng)目中的keepAlive怎么使用”文章吧。

keepAlive的使用

在開(kāi)發(fā)的過(guò)程中如果碰到經(jīng)常瀏覽需要緩存的頁(yè)面,而且頁(yè)面很長(zhǎng)需要記錄滾動(dòng)的位置這時(shí)就需要用到keepAlive。

一共有三個(gè)步驟

1、首先在路由中的mate屬性中記錄keepAlive,如果需要緩存則置為true。

path:'/index',
name:''index',
component:()=>import('../../index/index'),
meta:{keepAlive:true}

2、在創(chuàng)建router實(shí)例的時(shí)候加上scrollBehavior方法(keepAlive才會(huì)生效)。

let router=new Router({
    mode:"hash",//1、hash哈希:有#號(hào)。2、history歷史:沒(méi)有#號(hào)
    base:process.env.BASE_URL, //自動(dòng)獲取根目錄路徑
    scrollBehavior:(to,from,position)=>{
        if(position){
            return position
        }else{
            return {x:0,y:0}
        }
    },

3、需要緩存的router-view包上keep-alive(要有兩個(gè)router-view,一個(gè)是緩存的時(shí)候顯示,一個(gè)是不緩存的時(shí)候顯示,有的時(shí)候不需要緩存)。

<keep-alive>
    <router-view v-if="$router.meta.keepAlive"></router-view>
</keep-alive>
    <router-view v-if="!$router.meta.keepAlive"></router-view>

注意

在keep-alive中的組件會(huì)有兩個(gè)生命周期的鉤子函數(shù),activated和deactivated,其中activated是在組件第一次渲染時(shí)會(huì)被調(diào)用,而且之后每次緩存組件被激活都會(huì)被調(diào)用。所以一般使用時(shí)需要里面的代碼和created函數(shù)中的代碼一樣即可。

keepAlive的注意事項(xiàng)

問(wèn)題描述

今天在測(cè)試提到了一個(gè)bug,當(dāng)重復(fù)進(jìn)入相同的組建的時(shí)候,mounted和created內(nèi)的方法不觸發(fā),導(dǎo)致頁(yè)面展示不一樣

原因

<keep-alive> 包裹動(dòng)態(tài)組件時(shí),會(huì)緩存不活動(dòng)的組件實(shí)例,而不是銷(xiāo)毀它們。和 <transition> 相似,<keep-alive> 是一個(gè)抽象組件:它自身不會(huì)渲染一個(gè) DOM 元素,也不會(huì)出現(xiàn)在父組件鏈中。(所以不會(huì)觸發(fā)mounted和created事件鉤子)

當(dāng)組件在 <keep-alive> 內(nèi)被切換,它的 activated (激活)和 deactivated (不激活)這兩個(gè)生命周期鉤子函數(shù)將會(huì)被對(duì)應(yīng)執(zhí)行。

include and exclude

include (緩存的文件)和 exclude(不換存文件) 屬性允許組件有條件地緩存。

<!-- 逗號(hào)分隔字符串 -->
<keep-alive include="a,b">
  <component :is="view"></component>
</keep-alive>
 
<!-- 正則表達(dá)式 (使用 `v-bind`) -->
<keep-alive :include="/a|b/">
  <component :is="view"></component>
</keep-alive>
 
<!-- 數(shù)組 (使用 `v-bind`) -->
<keep-alive :include="['a', 'b']">
  <component :is="view"></component>
</keep-alive>

max

最多可以緩存多少組件實(shí)例。

<keep-alive :max="10">
  <component :is="view"></component>
</keep-alive>

以上就是關(guān)于“Vue項(xiàng)目中的keepAlive怎么使用”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問(wèn)一下細(xì)節(jié)

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

AI