在vue项目中,难免会有列表页面或者搜索结果列表页面,点击某一个结果之后,返回回来时,如果不对结果页面进行缓存,那么返回列表页面的时候会回到初始状态,但是我们想要的结果是返回这个页面还是搜索的结果列表,这时候就需要用到vue de keep-alive技术
但实际项目中,需要配合vue-router共同使用.
但实际项目中,需要配合vue-router共同使用.router-view
也是一个组件,如果直接被包在 keep-alive
里面,所有路径匹配到的视图组件都会被缓存:
如果只想 router-view
里面某个组件被缓存,怎么办?
路由中增加 router.meta 属性
// routes 配置
export default [
{
path: ‘/‘,
name: ‘home’,
component: Home,
meta: {
keepAlive: true // 需要被缓存
}
}, {
path: ‘/:id’,
name: ‘edit’,
component: Edit,
meta: {
keepAlive: false // 不需要被缓存
}
}
]
APP.vue中添加: