Vue 中activated的用法
Vue 中activated的用法
1. keep-alive
被 <keep-alive> 包裹的组件其会被缓存
创建两个子组件conpoment1,compoment2 ,其内容如下:
<template>
<div class="wrapper">
<ul class="content"></ul>
<button class="add" id="add" @click="add">添加子元素</button>
</div>
</template>
<script>
export default {
data() {
return {};
},
methods: {
add() {
let ul = document.getElementsByClassName("content")[0];
let li = document.createElement("li");
li.innerHTML = "我是添加的元素";
ul.appendChild(li);
}
}
};
</script> 修改App.vue中的代码如下:
<template> <div id="app"> <keep-alive> <router-view /> </keep-alive> </template>
当我们切换路由的时候,我们之前添加的子元素还回保存在那里:
如果是这样的话所有的页面都被缓存了,一些需要重新加载不需要缓存的我们可以通过v-if来实现。当然我们可以在路由中设置一个bool值来判断组件是否需要缓存,就像下面这样
// index.js
{
path: '/1',
name: 'component1',
component: () => import('../components/component1'),
meta: {
keepAlive: true // 判断是否缓存
}
},
{
path: '/2',
name: 'component2',
component: () => import('../components/component2'),
meta: {
keepAlive: false
}
} 然后我们的App.vue中只需要判断其keepAlive值即可
<div id="app"> <keep-alive> <router-view v-if="this.$route.meta.keepAlive" /> </keep-alive> <router-view v-if="!this.$route.meta.keepAlive" /> </template>
这时候我们回到页面中添加子元素并切换路由就会发现只有components1中的组件有缓存。
2. activated
在挂载后和更新前被调用的。
但如果该组件中没有使用缓存,也就是没有被<keep-alive>包裹的话,activated是不起作用的。
//components1中
created() {
console.log("1激活created钩子函数");
},
activated() {
console.log("1激活activated钩子函数");
},
mounted() {
console.log("1激活mounted钩子函数");
}
//components2中
created() {
console.log("2激活created钩子函数");
},
activated() {
console.log("2激活activated钩子函数");
},
mounted() {
console.log("2激活mounted钩子函数");
} 我们在2个组件中分别打印出其钩子函数执行情况。我们可以看到
在执行components1时候其是执行了activated钩子函数的,而components2则没有,因为components2并没有被<keep-alive>包裹,所以其并不会激活该钩子函数。
当我们再切换一次路由的时候,出现如下结果:
组件1中只执行 activated 钩子函数,而组件2则把创建和挂载的钩子函数都执行了。
这就是缓存的原因,components1对组件进行了缓存所以并不会再一次执行创建和挂载。
简单的说activated()函数就是一个页面激活后的钩子函数,一进入页面就触发;
所以当我们运用了组件缓存时,如果想每次切换都发送一次请求的话,需要把请求函数写在activated中,而写在created或mounted中其只会在首次加载该组件的时候起作用。
3. deactivated
触发时机:keep-alive组件停用时调用;
Vue.js 文章被收录于专栏
Vue.js

联想公司福利 1496人发布