您好,登錄后才能下訂單哦!
這篇“Vue項(xiàng)目中的keepAlive怎么使用”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“Vue項(xiàng)目中的keepAlive怎么使用”文章吧。
在開(kāi)發(fā)的過(guò)程中如果碰到經(jīng)常瀏覽需要緩存的頁(yè)面,而且頁(yè)面很長(zhǎng)需要記錄滾動(dòng)的位置這時(shí)就需要用到keepAlive。
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ù)中的代碼一樣即可。
今天在測(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 (緩存的文件)和 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>
最多可以緩存多少組件實(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è)資訊頻道。
免責(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)容。