解决Vue中的生命周期beforeDestory不触发的问题(用了keep-alive)

原因:给router-view加了个keep-alive导致组件缓存了,所以不会触发beforeDestory。

vue项目中,在页面中使用了定时器。正常情况下,我们在生命周期 beforeDestory 中关闭即可,一旦页面中使用了keep-alive 进行缓存,此时 beforeDestory 会失效。需要在 deactivated 钩子函数去关闭,他是 keep-alive 特有的钩子函数。

keep-alive 缓存过的页面

在这里插入图片描述

// 开启定时器
activated() {
        this.getInfo();
        this.timer = setInterval(() => {
            setTimeout(this.getInfo);
        }, 1000 * 10);
    }
    // this.geyInfo() 是具体做的事

在这里插入图片描述

// 关闭定时器
deactivated(){
	clearInterval(this.timer)
	this.timer = null
}

在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值