Vue中的keep-alive组件
keep-alive
- router-view 也是一个组件,如果直接被包在keep-alive里面,所有路径匹配到的视图组件都会缓存,
保持生存
- keep-alive是Vue内置的一个组件,可以使被包含的组件保留状态,或避免重新渲染
属性 | 描述 |
---|---|
include(包含) | 字符串或正则表达式,只有匹配的组件会被缓存 |
exclude(不包含) | 字符串或者正则表达式,任何匹配的组件都不会被缓存 |
<keep-alive exclude="profile,User">
<router-view></router-view>
</keep-alive>
上面这行代码将会把
name属性值
为profile
和user
的两个组件对于keep-alive
排除在外,是他们可以正常的被创建和销毁。
当有多个组件是,需要用逗号将他们隔开,切记,不要加空格或者其他符号
:第二个组件没有生效,只有第一个组件有用。
使用keep-alive标签将要保存live的组件包裹起来
router -view 也是一个组件,如果直接被包括在keep-alive里面,所有的路劲匹配到的视图组件都会被缓存。
<keep-alive>
<router-view></router-view>
</keep-alive>
小问题(学习老师的解决问题的思路)
<script>
export default {
name: '',
data(){
return{
message:'你好呀',
path:'/home/news'
}
},
//实例创建后开始执行
created(){
// document.title='首页'
console.log(' home created');
},
//将tamplate等模板相关的东西被挂载到DOM就会回调这个生命周期函数
// mounted(){
// console.log('mounted')
// },
// //界面发生刷新后就会回调
// update(){
// console.log('update')
// }
destroyed(){
console.log(' home destrotyed')
},
// 这两个函数只有该组件使用了keep-alive时才有效
activated(){
console.log(this.path);
this.$router.push(this.path);
},
beforeRouteLeave(to,from,next){
console.log(this.$route.path)
this.path = this.$route.path;
next();
}
}
</script>
在home组件中使用path变量保存路径,然后使用
beforeRouteLeave
保存路由跳出的url,使用activated
在下一次活跃路由时,将url定向到原来跳出的地点。