vue中setInterval()和setTimeout()的使用和失效问题。

在vue项目中是用了setInterval()。

this.queryTimer = setInterval(() => {

        this.qryBatchCheckResult()

      }, 5000)
这样直接使用没有问题 可以实现循环调用函数。

但是再后面需要 清除定时器时,使用clearInterval() 。
clearInterval(this.queryTimer)
这样使用是无法停止的。

如果这样:window.setInterval()

window.clearInterval()

就可以变成正常效果。

不加上window直接调用setInterval() 返回的并不是所谓的定时器id,而是下图的数据。

导致clearInterval(),无法清除定时器。

然后 使用window来调用

setInterval() 和 clearInterval(),或者只用window调用setInterval(),都是正常的。

关键就是setInterval(),能不能返回正常的定时器id。

 

根本的原因就是:vue重写了setInterval()方法。返回的是定时器对象,里面有个私有属性_id,在赋值是也可以直接使用。

所以如果不使用window调用,就要通过_id来拿到定时器id。如果统一使用window来调用,则没有任何不同。

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值