vue keep-alive列表页缓存 详情页返回上一页不刷新,定位到之前位置

需求: 商品列表页面浏览,进入商品详情,点击返回仍然是之前浏览的位置 实现: 使用vue的keep-alive的include属性给组件做动态缓存,从详情页返回不变,从其他页面进入列表页则刷新 加需要缓存...

需求:

商品列表页面浏览,进入商品详情,点击返回仍然是之前浏览的位置

实现:

使用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是否已缓存某些页面,只有从商情详情返回已缓存的列表页才是无刷新,未缓存的列表页面仍然需要新缓存

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
admin
admin

651 篇文章

作家榜 »

  1. admin 651 文章
  2. 粪斗 185 文章
  3. 王凯 92 文章
  4. 廖雪 78 文章
  5. 牟雪峰 12 文章
  6. 李沁雪 9 文章
  7. 全易 2 文章
  8. Garmcrypto7undop 0 文章