在Vue项目中keepAlive的使用(超级实用版!!!)
在开发的过程中如果碰到经常浏览需要缓存的页面,而且页面很长需要记录滚动的位置这时就需要用到keepAlive。一共有三个步骤1、首先在路由中的mate属性中记录keepAlive,如果需要缓存则置为true。path:'/index',name:''index',component:()=>import('../../index/index'),meta:{keepAlive:true}2、
·
在开发的过程中如果碰到经常浏览需要缓存的页面,而且页面很长需要记录滚动的位置这时就需要用到keepAlive。
一共有三个步骤
1、首先在路由中的mate属性中记录keepAlive,如果需要缓存则置为true。
path:'/index',
name:''index',
component:()=>import('../../index/index'),
meta:{keepAlive:true}
2、在创建router实例的时候加上scrollBehavior方法(keepAlive才会生效)。
let router=new Router({
mode:"hash",//1、hash哈希:有#号。2、history历史:没有#号
base:process.env.BASE_URL, //自动获取根目录路径
scrollBehavior:(to,from,position)=>{
if(position){
return position
}else{
return {x:0,y:0}
}
},
3、需要缓存的router-view包上keep-alive(要有两个router-view,一个是缓存的时候显示,一个是不缓存的时候显示,有的时候不需要缓存)。
<keep-alive>
<router-view v-if="$router.meta.keepAlive"></router-view>
</keep-alive>
<router-view v-if="!$router.meta.keepAlive"></router-view>
注意
在keep-alive中的组件会有两个生命周期的钩子函数,activated和deactivated,其中activated是在组件第一次渲染时会被调用,而且之后每次缓存组件被激活都会被调用。所以一般使用时需要里面的代码和created函数中的代码一样即可。
更多推荐
已为社区贡献2条内容
所有评论(0)