最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
基于vue中keep-alive缓存问题的解决方法
时间:2022-06-25 15:37:27 编辑:袖梨 来源:一聚教程网
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();
}
相关文章
- 电子商务平台类型与主流模式解析 - 2026最新分类指南 06-22
- Iconfont图标库使用教程 - 2026最新入门指南 06-22
- 网店客服工作内容与技能要求 - 2026最新实用指南 06-22
- 米家智能家电官方选购平台 - 2026最新款全屋智能解决方案 06-22
- 2026年了 - 还在用过时的网络用语吗 06-22
- 共享充电宝租赁服务 - 便捷随借随还的移动电源 06-22