4种方案详解如何实现准时的setTimeout

本文分析了JavaScript中setTimeout延迟不准的问题,深入探讨了浏览器的事件循环和消息队列对定时器的影响。通过示例展示了在代码逻辑中插入额外操作导致的误差,并提出了四种解决方案:while循环(会导致页面卡死)、Web Worker(可减少干扰但仍有局限)、requestAnimationFrame(时间间隔不固定)。文章提供了相关视频和文章链接以供进一步学习。
摘要由CSDN通过智能技术生成

timer();

而我们如果在 setTimeout 还未执行期间加入一些额外的代码逻辑,再来看看这个差值。

window.setTimeout(function() { instance(); }, speed);

for(var x=1, i=0; i<10000000; i++) { x *= (i + 1); }

}

可以看出,这大大加剧了误差。

可以看到随着时间的推移, setTimeout 实际执行的时间和理想的时间差值会越来越大,这就不是我们预期的样子。类比真实的场景,对于一些倒计时以及动画来说都会造成时间的偏差都是不理想的。

那么,从这个现象 《大厂前端面试题解析+Web核心总结学习笔记+企业项目实战源码+最新高清讲解视频》无偿开源 徽信搜索公众号【编程进阶路】 来看一下,为什么 setTimeout 会不准时呢?

因为我们的代码往往并不是只有一个 setTimeout,大多数会遇到以下情况。

详细要从浏览器的事件循环讲起,但是讲事件循环的文章太多了,文本就不再累赘地详细展开讲解。

视频

  • https://www.youtube.com/watch?v=8aGhZQkoFbQ
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值