vue缓存之动态keep-alive

今天遇到一个优化需求,用vue写的webapp,客户想要从商品列表页到商品详情页然后点击返回的时候商品列表页不刷新,但是从活动页面进入商品列表页的时候商品列表页需要刷新,在网上查了一下,vue的keepAlive抽象组件可以实现。

参考了一篇挺全的技术博客:https://www.jianshu.com/p/11f7dbc07ad3,里面的几种方案都试了一下,确实却在一些bug,从活动页进去有时候还是进的缓存的页面。调用销毁组件的方式只能成功一次,后面就都缓存不上了。

我的最优解决方案:缓存页面仍然设置成keepAlive:true,这样每次这个页面都是缓存的,在需要刷新时再在缓存的页面根据参数动态调用初始化数据接口刷新。此动态刷新参数交由vuex管理。

1.商品路由参数:仍然设置成keepalive:true,缓存此页面

2.vuex设置一个是否缓存数据的标识

3.商品列表用watch监听状态的变化,isCacheProductList==true就不刷新数据,false就重新加载数据。

商品加载成功以后更新状态,isCacheProductList状态未默认的状态true

4.活动组件在跳转之前,更改vuex里面的状态为false,即不缓存,刷新页面

 总结:原理就是页面仍然时缓存的,只是需要刷新的时候根据状态手动更新状态,重新加载数据实现刷新。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值