vue-cli v3.0
include - 字符串或正則表達(dá)式。只有名稱匹配的組件會(huì)被緩存。
exclude - 字符串或正則表達(dá)式。任何名稱匹配的組件都不會(huì)被緩存。(在這里寫三目運(yùn)算,來判斷是否緩存組件)
max - 數(shù)字。最多可以緩存多少組件實(shí)例。
<keep-alive> 是用在其一個(gè)直屬的子組件被開關(guān)的情形。如果你在其中有 v-for 則不會(huì)工作。
如果有上述的多個(gè)條件性的子元素,<keep-alive> 要求同時(shí)只有一個(gè)子元素被渲染。
<keep-alive include="AboutIndex" max="1" :exclude="isKeepalive?'':'AboutIndex'">
<router-view/>
</keep-alive>
//AboutIndex 是需要被緩存的組件 是組件name名
data() {
return {
isKeepalive: false,//是否對(duì)該組件進(jìn)行緩存
};
},
我這邊是使用watch 來判斷的路由,根據(jù)個(gè)人情況來使用。你也可以使用組件路由判斷。
watch: {
//監(jiān)聽路由 判斷是否進(jìn)行keep-alive動(dòng)態(tài)緩存
$route: function(to, from) {
if (to.name === "detail"||to.name === "about") {
this.isKeepalive = true;
}else{
this.isKeepalive = false;
}
}
},