vue中 keep-alive以及activated,deactivated生命周期的用法
vue官网的描述:
<keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 <transition> 相似,<keep-alive> 是一个抽象组件:它自身不会渲染一个 DOM 元素,也不会出现在父组件链中。
当组件在 <keep-alive> 内被切换,它的 activated 和 deactivated 这两个生命周期钩子函数将会被对应执行。
通过描述我们知道,它会缓存不活动的组件,而不是销毁。这样组件之间的切换就能保存上个组件的状态,而不是切换之后又得重新操作。
先定义两个组件
<template>
<div>
<h2>我是A组件</h2>
<div>
<button @click="show = !show" class="isShow">切换</button>
</div>
<div v-if="show" class="show">[显示]</div>
<div v-if="!show" class="hidden">[隐藏]</div>
</div>
</template>
<script>
export default {
name: "A",
data() {
return {
show: true,
};
},
methods: {},
mounted() {},
created() {
console.log("created");
},
activated() {
console.log("activated");
},
deactivated() {
console.log("deactivated");
},
};
</script>
<style>
.isShow {
width: 80px;
height: 40px;
color: #ffffff;
background: #000;
font-size: 20px;
outline: none;
border: none;
}
.show, .hidden {
font-size: 20px;
font-weight: 700;
margin-top: 20px;
}
</style>
<template>
<div>
<h2>我是B组件</h2>
</div>
</template>
<script>
export default {
name: "B",
components: {},
data() {
return {};
},
methods: {},
mounted() {},
};
</script>
<style>
</style>
把A,B组件引入到父组件中
<template>
<div class="father">
<div class="btn">
<button @click="currentView ='A'" class="a">A</button>
<button @click="currentView ='B'" class="b">B</button>
</div>
<div>
<keep-alive>
<component :is="currentView"></component>
</keep-alive>
<!-- <component :is="currentView"></component> -->
</div>
</div>
</template>
<script>
import A from '../../components/A'
import B from '../../components/B'
export default {
components: {
A,
B
},
data(){
return{
currentView: 'B'
}
}
}
</script>
<style>
.father {
width: 100%;
text-align: center;
margin: 100px auto;
}
.a {
width: 100px;
margin-right: 50px;
}
.b {
width: 100px;
}
</style>
页面如下
我们点击按钮b切换到a组件,可以看到created和activated执行了。然后我们把a组件的show切换成hide,在进行组件切换。
效果如下:
可以看到离开的A组件的时候deactivated执行了(每次离开当前组件都会执行),再切换回来activated执行了(activated每次切换回来都会执行)、created没有执行(因为组件是缓存并不是销毁,所以created只会执行一次)。而且我们在组件切换之前改的hide,切换回来还是hide,这样就能一直保存组件的状态了。
可以看到离开的A组件的时候deactivated执行了(每次离开当前组件都会执行),再切换回来activated执行了(activated每次切换回来都会执行)、created没有执行(因为组件是缓存并不是销毁,所以created只会执行一次)。而且我们在组件切换之前改的hide,切换回来还是hide,这样就能一直保存组件的状态了。
作者:天微亮gxf
链接:https://www.jianshu.com/p/0272c0fe9392
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
浙公网安备 33010602011771号