解决vue中keep-alive缓存问题

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();
    }

发布了59 篇原创文章 · 获赞 29 · 访问量 15万+

猜你喜欢

转载自blog.csdn.net/dongguan_123/article/details/80910231
今日推荐