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缓存问题的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍keep-alive不能缓存多层级路由菜单问题解决,包括了keep-alive不能缓存多层级路由菜单问题解决的使用技巧和注意事项,需要的朋友参考一下 这出现的原因是多级路由导致的,就是router-view嵌套 在层级不同的router-view中切换tag会出现缓存数据失效的问题。目前keep-alive可以有效缓存一级,二级的路由菜单,3级以上菜单并不能做到缓存,这里提供一个解决
当前代码如下,需要实现不同页面的切换,并且实现缓存效果,但目前缓存效果未实现。 在onMounted中输出1来判断是否缓存成功,即首次加载该页面输出1,进入二级界面后返回将不在输出1。尝试修改后如下 缓存虽然实现了,但是页面切换变得混乱。如何同时保留页面切换与缓存的效果呢?
本文向大家介绍示例vue 的keep-alive缓存功能的实现,包括了示例vue 的keep-alive缓存功能的实现的使用技巧和注意事项,需要的朋友参考一下 本篇文章主要介绍了vue 的keep-alive缓存功能的实现,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 <keep-alive>是Vue的内置组件,能在组件切换过程中将状态保留在
本文向大家介绍vue项目优化之通过keep-alive数据缓存的方法,包括了vue项目优化之通过keep-alive数据缓存的方法的使用技巧和注意事项,需要的朋友参考一下 <keep-alive>是Vue的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染DOM。 <keep-alive> 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。和 <transition> 相似,<ke
本文向大家介绍vue中keep-alive内置组件缓存的实例代码,包括了vue中keep-alive内置组件缓存的实例代码的使用技巧和注意事项,需要的朋友参考一下 需求: home 组件中有一个 name 的 data 数据。这个数据修改之后,再切换到其他的组件。再切换到 home 组件,希望 home 中 name 这个值是之前修改过的值。希望组件有缓存。 keep-alive 的使用方式: 将
本文向大家介绍vue keep-alive 动态删除组件缓存的例子,包括了vue keep-alive 动态删除组件缓存的例子的使用技巧和注意事项,需要的朋友参考一下 业务需求: 切换tab页标签的时候(路由前进的时候),缓存当前组件数据,关闭tab页标签的时候清除组件缓存。 实现: 1、先在store的state里面设置一个要缓存数组 2、在进到子页面的时候,更新store的数组,把将要缓存组件