vue项目中定时器无法清除的原因解决
当前页面有定时器,并且定时器在离开页面时,有清除
beforeDestroy() { if (this.timer) { clearInterval(this.timer) this.timer = null } },
原因
当前页面 (假设当前页面为page1) 的定时器是在一系列前置请求之后,才触发的。【此定时器前面有一堆请求,等这堆请求完成之后,定时器才会被触发】
路由切换过快的时候,切换到了其他页面(page2,page3...)时,当前页面(page1)的beforeDestroy函数已经触发了,但是当前页面(page1)的定时器还没有触发。当切换到其他页面(page2,page3...)的时候,当前页面(page1)的定时器才执行。
此种情况下,定时器无法清除
解决:执行定时器的时候,加个判断即可
判断路由是否为当前page1的路由名称。如果是当前的路由名称,才开始执行定时器
假如page1的路由name是【page1】
vue2和vue3思路都是如此
if (this.$route.name === 'page1') { this.timer = setInterval(() => { this.getListPage() }, 3 * 1000) }
补:前端Vue项目中定时器清除问题
方法1:常规使用和清除
clearInterval(this.timer)//使用前先清空定时器 this.timer = setInterval(()=>{ console.log(1) }, 1000)
方法2:使用数组存储每一个定时器的标识,避免某些原因导致定时器未能清除 (如:页面重复初始化)
if(!window.timer){ window.timer = []} // 将存起来的定时器一并清除 window.timer.map(item=>{ clearInterval(item) }) const timerId = setInterval(()=>{ console.log(1) }, 1000) window.timer.push(timerId)
到此这篇关于vue项目中定时器无法清除的原因解决的文章就介绍到这了,更多相关vue 定时器无法清除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue状态模式实现窗口停靠功能(灵动、自由, 管理后台Admin界面)
这篇文章主要介绍了Vue状态模式实现窗口停靠功能(灵动、自由, 管理后台Admin界面),本文通过实例代码文字说明给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2020-03-03vue2项目导出操作实现方法(后端接口导出、前端直接做导出)
这篇文章主要给大家介绍了关于vue2项目导出操作实现方法的相关资料,文中介绍的是后端接口导出、前端直接做导出,通过代码介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下2024-05-05解决VUE mounted 钩子函数执行时 img 未加载导致页面布局的问题
这篇文章主要介绍了解决VUE mounted 钩子函数执行时 img 未加载导致页面布局的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-07-07基于vue-upload-component封装一个图片上传组件的示例
这篇文章主要介绍了基于vue-upload-component封装一个图片上传组件的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-10-10
最新评论