当前位置:网站首页>用 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);

 欢迎来访船长在船上的博客,如有疑问可以留言、评论,看到后会及时回复。  

原网站

版权声明
本文为[船长在船上]所创,转载请带上原文链接,感谢
https://blog.csdn.net/SmartJunTao/article/details/126134586