keep-alive的使用
1.首先在我们的app.vue中定义keep-alive
<keep-alive>
<router-view v-if="$route.meta.keepAlive"/>
</keep-alive>
<router-view v-if="!$route.meta.keepAlive"/>
2.在router/index.js即我们的路由文件中,定义meta信息(因为keepAlive是自己定义在meta中的)
// list是我们的搜索结果页面
{
path: '/list',
name: 'List',
component: resolve => require(['@/pages/list'], resolve),
meta: {
isUseCache: false, // 用来判断是否需要使用缓存数据
keepAlive: true // 通过此字段判断是否需要缓存当前组件
}
},
刷新数据or缓存数据的实现
1.与缓存相关的钩子函数
设置了keepAlive缓存的组件:
第一次进入:beforeRouterEnter ->created->…->activated->…->deactivated
后续进入时:beforeRouterEnter ->activated->deactivated
// list组价的activated钩子
activated() {
// isUseCache为false时才重新刷新获取数据
// 因为对list使用keep-alive来缓存组件,所以默认是会使用缓存数据的
if(!this.$route.meta.isUseCache){
this.list = []; // 清空原有数据
this.onLoad(); // 这是我们获取数据的函数
}
this.$route.meta.isUseCache = false;
},
由于我们只要列表到详情页的时候缓存列表页的数据,所以我们要在列表页的beforeRouteLeave的钩子判断,如果前往的是详情页面,则缓存数据:
// 列表页面的beforeRouteLeave钩子函数
beforeRouteLeave (to, from, next) {
if (to.name == 'Detail') {
from.meta.isUseCache = true;
}
next();
},
3.注意,缓存页面是会保存返回前页面的滚动条位置,如果需要返回顶部,则在router中定义方法
routes: [
{
path: '/detail',
name: 'Detail',
component: resolve => require(['@/pages/detail'], resolve)
}
],
scrollBehavior (to, from, savedPosition) {
if (savedPosition) {
return savedPosition
} else {
if (from.meta.keepAlive) {
from.meta.savedPosition = document.body.scrollTop;
}
return { x: 0, y: to.meta.savedPosition || 0 }
}
}