基于vue中keep-alive缓存问题的解决方法
2018-09-21 10:17
1686 查看
vue开发的时候,我们经常会有这样的需求:开发一个详细页面来展示商品的详细信息,根据列表页传入的id进行请求,拿到对应的数据进行渲染。
但是一般在路由上都会加上keep-alive保持数据的状态,除非强制无缓存刷新,这就导致第一次进入详情页面时,可以在created中拿到id,但是返回后,再点击进入,就不会再走相应的生命周期了,无法拿到新的id
这时候可以使用vue的$destroy()方法
这是vue的一个生命周期,完全销毁一个实例。清理它与其它实例的连接,解绑它的全部指令及事件监听器。
不用$destroy方法的时候可以用watch监听路有变化来实现效果
created() { this.goodsId = this.$route.query.goodsId; this.getGoodsInfo(); }, watch: { '$route'(to, from) { if(to.name === 'GoodsDetail') { this.goodsId = to.query.goodsId; this.getGoodsInfo(); } } }
用$destroy方法
created() { if(this.goodsId !== this.$route.query.goodsId) { this.$destroy(); } this.goodsId = this.$route.query.goodsId; this.getGoodsInfo(); }
以上这篇基于vue中keep-alive缓存问题的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 使用vue的时候我们使用keep-alive会将页面缓存的解决方法
- vue解决使用webpack打包后keep-alive不生效的方法
- 基于vue打包后字体和图片资源失效问题的解决方法
- 解决keep-alive缓存问题
- 基于vue-resource jsonp跨域问题的解决方法
- vue 使某个组件不被 keep-alive 缓存的方法
- 解决URLDownloadToFile缓存问题的两种方法
- 解决jquery之get缓存问题的最简单方法
- 在表示层禁用浏览器缓存的方法,以解决应用开发不能即时刷新体现修改结果的问题
- AJAX缓存问题产生的缘由以及几种解决方法
- iframe缓存不刷新问题彻底解决方法
- iframe缓存不刷新问题彻底解决方法
- 一种缓存切片更新问题的解决方法
- IE缓存问题的解决方法
- ajax的缓存问题分析和解决方法
- IE6背景图片不缓存问题解决方案及图片使用策略多个方法小结
- IE6下CSS图片缓存问题解决方法
- ArcGIS 10中WFS缓存问题的解决方法与原理
- AJAX 缓存问题的两种解决方法(IE)
- AJAX 缓存问题的两种解决方法(IE)