您当前的位置:首页 > 网站建设 > javascript
| php | asp | css | H5 | javascript | Mysql | Dreamweaver | Delphi | 网站维护 | 帝国cms | React | 考试系统 | ajax |

Vue如何优雅的清除定时器

51自学网 2022-05-02 21:35:54
  javascript

前言

清除定时器,相信有相当一部分人是这么写的:

export default {  data() {    reurn {      timer: null    }  },    mounted() {    this.timer = setInterval(() => {      console.log('setInterval')    }, 2000)  },    beforeDestroy() {    clearInterval(this.timer)  }}

这是一段常见的代码,至少我身边的好几个小伙伴(1-3年经验的都有)都是这么写的,这里存在3个不优雅的问题:

  • clearInterval 后没有清空 timer 为 null。
  • 开启定时器和清除定时器的代码分散开在两个地方,有损可读性/维护性,用尤大大的话说,这使得我们比较难于程序化地清理我们建立的东西。
  • timer 被定义在 data 里,实际上 timer 不需要什么响应式操作,定义在 data 里是没必要的,反而造成性能浪费。

优化

直接上代码:

export default {  data() {    reurn {    }  },    mounted() {    let timer = setInterval(() => {      console.log('setInterval')    }, 2000)    this.$once('hook:beforeDestroy', () => {      clearInterval(timer)      timer = null    })  }}

这里使用 hook 监听 beforeDestroy 生命周期,这样 timer 只需被定义在生命周期里,以上的问题就全部解决了。

衍生问题:beforeDestroy 没有触发?

在后台系统中,我们常常会设置页面缓存,而当路由被 keep-alive 缓存时是不走 beforeDestroy 生命周期的,所以有些小伙伴以为在 beforeDestroy 清除定时器就完事了,甚至都没有检查一下,实际上定时器并没有被清除掉。知道了原因也就好解决了,借助 activated 和 deactivated 这两个生钩子:

export default {  data() {    reurn {    }  },    mounted() {    let timer = setInterval(() => {      console.log('setInterval')    }, 2000)    this.$on('hook:activated', () => {      if (timer === null) { // 避免重复开启定时器        timer = setInterval(() => {          console.log('setInterval')        }, 2000)      }    })    this.$on('hook:deactivated', () => {      clearInterval(timer)      timer = null    })  }}

这里需要注意一下,由于缓存原因,所以需要用 $on 而不是 $once,不然执行一次后就不会再触发了。

到此这篇关于Vue如何优雅的清除定时器的文章就介绍到这了,更多相关Vue 清除定时器内容请搜索wanshiok.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持wanshiok.com!


最全的package.json解析
react为什么不推荐使用index作为key
51自学网,即我要自学网,自学EXCEL、自学PS、自学CAD、自学C语言、自学css3实例,是一个通过网络自主学习工作技能的自学平台,网友喜欢的软件自学网站。
京ICP备13026421号-1