在Vue中,除了`beforeDestroy`生命周期钩子函数,还有哪些方法可以在组件销毁时清理定时器?

简介: 在Vue中,除了`beforeDestroy`生命周期钩子函数,还有哪些方法可以在组件销毁时清理定时器?

除了在 beforeDestroy 生命周期钩子函数中清除定时器,还可以通过路由拦截和 $once 一次性侦听事件来实现。

示例如下:

  1. 在组件内设置定时器,并存储由 setInterval() 返回的 ID 值:
    // 组件中保存定时器
    this.testSetinterval = setInterval(() => {
         
      setTimeout(() => {
         
        console.log('test clearInterval')
      }, 0)
    }, 2000)
    
  2. 拦截前端路由,在组件内的 beforeDestroy 钩子函数中清除定时器:
    router.beforeEach((to, from, next) => {
         
      clearInterval(this.testSetinterval)
    })
    
  3. 通过 $once 一次性侦听一个事件,在组件内的 beforeDestroy 钩子函数中清除定时器:
    mounted () {
         
      const that = this
      // 组件中保存定时器
      this.testSetinterval = setInterval(() => {
         
        setTimeout(() => {
         
          console.log('test clearInterval')
        }, 0)
      }, 2000)
      // 监听 beforeDestroy 事件
      this.$once('hook:beforeDestroy', () => {
         
        clearInterval(that.testSetinterval)
      })
    }
    

上述三种方法都可以在组件销毁时清除定时器,你可以根据自己的需求选择适合的方法。

相关文章
|
3天前
|
JavaScript
Ant design Vue 父子组件传递(代码案例--不懂的地方可以私信本博主)
Ant design Vue 父子组件传递(代码案例--不懂的地方可以私信本博主)
9 0
|
3天前
|
JavaScript 前端开发
ant design vue 配置菜单外部打开
ant design vue 配置菜单外部打开
10 0
|
3天前
|
JavaScript
ant design vue 在列表中使用插槽 例如当性别为0的时候在列表中我想显示男
ant design vue 在列表中使用插槽 例如当性别为0的时候在列表中我想显示男
7 0
|
3天前
|
JavaScript 前端开发
vue 实现在线预览PDFpdf文件
vue 实现在线预览PDFpdf文件
14 0
|
3天前
|
JavaScript
vue下拉列表
vue下拉列表
7 0
vue下拉列表
|
3天前
|
JavaScript 前端开发 API
vue与jqyery的区别
vue与jqyery的区别
|
4天前
|
JavaScript 前端开发 UED
Vue工具和生态系统: Vue.js和服务器端渲染(SSR)有关系吗?请解释。
Vue.js是一个渐进式JavaScript框架,常用于开发单页面应用,但其首屏加载较慢影响用户体验和SEO。为解决此问题,Vue.js支持服务器端渲染(SSR),在服务器预生成HTML,加快首屏速度。Vue.js的SSR可手动实现或借助如Nuxt.js的第三方库简化流程。Nuxt.js是基于Vue.js的服务器端渲染框架,整合核心库并提供额外功能,帮助构建高效的应用,改善用户体验。
5 0
|
5天前
|
Web App开发 JavaScript 开发者
Vue工具和生态系统:什么是Vue DevTools?如何使用它?
Vue Devtools是Vue.js官方的浏览器扩展,用于简化应用调试和优化。可在Chrome和Firefox等浏览器上安装,集成到开发者工具中。安装步骤包括下载源码、npm安装、修改manifest.json并加载编译后的扩展。启用后,开发者能查看Vue组件树,检查属性,并在允许的情况下编辑data,提升开发效率。
6 0
|
6天前
|
JavaScript 测试技术
vue不同环境打包环境变量处理
vue不同环境打包环境变量处理
15 0
|
6天前
|
JavaScript
Vue Steps步骤组件用法
Vue Steps步骤组件用法
12 0