原文链接: https://dsx2016.com/?p=716微信公众号: 大师兄2016
需求:
商品列表页面浏览,进入商品详情,点击返回仍然是之前浏览的位置
实现:
使用vue
的keep-alive
的include
属性给组件做动态缓存,从详情页返回不变,从其他页面进入列表页则刷新
加需要缓存的列表页面定义一个数据集在vuex
state:{
pageListArr:[]
}
列表页的name
为proList
,详情页的name
为proDetail
,只有PageListArr
包含的字段才会被缓存,如pageListArr.push("proList")
<keep-alive :include="pageListArr">
<router-view></router-view>
</keep-alive>
思路:
在页面初始化前,获取来源页面的name
和要去加载页面的name
.
在这里使用全局导航守卫
router.beforeEach((to, from, next) => {
// 来源页面name -> from.name
// 去往页面name -> to.name
// 如果要跳转的页面为商品列表,且不是从商品详情返回或者跳转
if(to.name===`proList`&&from.name!==`proDetail`){
pageListArr.push(`proList`)
}
// 来源为商品页面返回列表页面
if(to.name===`proList`&&from.name===`proDetail`){
console.log(`不做处理`)
}
})
当多个不同的列表页面需要设置缓存时,如分类商品列表,活动商品列表
需要先判断pageListArr
是否已缓存某些页面,只有从商情详情返回已缓存的列表页才是无刷新,未缓存的列表页面仍然需要新缓存
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。