当前位置:网站首页>用 setTimeout 来实现 setInterval
用 setTimeout 来实现 setInterval
2022-08-03 20:31:00 【船长在船上】
️ 作者:船长在船上
主页:来访地址船长在船上的博客
简介:高级前端开发工程师,专注前端开发,欢迎咨询交流,共同学习!感谢:如果觉得博主的文章不错或者对你的工作有帮助或者解决了你的问题,可以关注、支持一下博主,如果三连收藏支持就会更好,在这里博主不胜感激!!!如有疑问可以留言、评论,看到后会及时回复。

(1)用 setTimeout()方法来模拟 setInterval()与 setInterval()之间的什么区别?
首先来看 setInterval 的缺陷,使用 setInterval()创建的定时器确保了定时器代码规则地插
入队列中。这个问题在于:如果定时器代码在代码再次添加到队列之前还没完成执行,
结果就会导致定时器代码连续运行好几次。而之间没有间隔。不过幸运的是:javascript
引擎足够聪明,能够避免这个问题。当且仅当没有该定时器的如何代码实例时,才会将
定时器代码添加到队列中。这确保了定时器代码加入队列中最小的时间间隔为指定时间。
这种重复定时器的规则有两个问题:1.某些间隔会被跳过 2.多个定时器的代码执行时间
可能会比预期小。
下面举例子说明:
假设,某个 onclick 事件处理程序使用 setInterval()来设置了一个 200ms 的重复定时器。
function say(){
setTimeout(say,200);
};
setTimeout(say,200);
//或者
setTimeout(function(){
setTimeout(arguments.callee,200);
},200);欢迎来访船长在船上的博客,如有疑问可以留言、评论,看到后会及时回复。
边栏推荐
猜你喜欢
随机推荐
leetcode 2119. Numbers reversed twice
【HiFlow】经常忘记签到怎么办?使用腾讯云场景连接器每天提醒你。
力扣59-螺旋矩阵 II——边界判断
博士申请 | 美国明尼苏达大学葛畅教授招收隐私数据管理方向全奖博士/硕士/博后/访问学者...
收藏-即时通讯(IM)开源项目OpenIM-功能手册
一种能有效缓解环境噪声对音频质量干扰的方案
华为设备配置VRRP负载分担
leetcode 326. 3 的幂
alicloud3搭建wordpress
leetcode refers to Offer 58 - II. Left Rotate String
Power button - 203 - remove the list elements linked list
华为设备VRRP配置命令
wordpress建立数据库连接时出错
算法--交错字符串(Kotlin)
直播平台怎么搭建,针对输入框的各种组件
ESP8266-Arduino编程实例-WS2812驱动
转运RNA(tRNA)甲基化修饰7-甲基胞嘧啶(m7C)|tRNA-m7G
leetcode 899. 有序队列
leetcode 剑指 Offer 15. 二进制中1的个数
nvm的使用 nodejs版本管理,解决用户名是汉字的问题









