vue页面详情页返回列表页_Vue keep-alive列表页缓存 详情页返回上一页不刷新,定位到之前位置_良笙_前端开发者...

需求:

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

26298cb6b33f152d632f4ecabb7d57b7.png

实现:

使用 keep-alive 的 include 属性给组件做动态缓存,从详情页返回不变,从其他页面进入列表页则刷新

加需要缓存的列表页面定义一个数据集在 vuex

state:{

pageListArr:[]

}

列表页的 name 为 proList ,详情页的 name 为 proDetail ,只有 PageListArr 包含的字段才会被pageListArr.push("proList")

思路:

在页面初始化前,获取来源页面的 name 和要去加载页面的 name .

436fda07d8aa3191f304b2f94c247742.png

在这里使用全局导航守卫

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 是否已

e9af1ef6fadbf755864500a3282f21a6.png

总结

以上所述是小编给大家介绍的开发者网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值