解决Vue中的生命周期beforeDestory不触发的问题(用了keep-alive)
给router-view加了个keep-alive导致组件缓存了,所以不会触发beforeDestory和destoryed
·
原因:给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条内容
所有评论(0)