js中两种定时器的本质区别

这里主要介绍常用的setTimeout 和 setInterval。
  1. 两个共同点:
  • setTimeout和setInterval这两个定时器一旦触发,就是和js程序并行执行的,也就是他们并不在一个时间线上。计时器的作用是仅仅是做一个计划,那就是每隔一段时间执行一次目标方法。<b>下面的例子就证明了这一点,17ms之前,程序走就执行到了下面。</b>
    var t = null;
    var f = null;
    var i = 0;

     function a() {
         i++;
         if (i == 20) {
             return;
         }
         t = setTimeout(a, 17);
     }
     a();
     console.log(i); // 1
    
  1. 两个本质上的不同:异步调用运行机制不同
  • setTimeout异步运行过程

     btn.onclick = function(){
         setTimeout(function(){
             console.log(1);
         },250);
     }
    

<b>如果上面代码中的onclick事件处理程序执行了300ms,那么定时器的代码至少要在定时器设置之后的300ms后才会被执行。队列中所有的代码都要等到javascript进程空闲之后才能执行,而不管它们是如何添加到队列中的.</b>

  • setInterval导致两个问题:1、某些间隔被跳过;2、多个定时器的代码执行之间的间隔可能比预期的小。
    <b>假设,某个onclick事件处理程序使用serInterval()设置了200ms间隔的定时器。如果事件处理程序花了300ms多一点时间完成,同时定时器代码也花了差不多的时间,就会同时出现跳过某间隔的情况</b>
    • <b>通俗来讲,setInterval会严格按照规定时间准备事件,不管执不执行,但是队列中只能有一个队列未执行,如果插入的时候发现多了就取消这次事件排队。</b>

3、为了避免setInterval()定时器的问题,可以使用链式setTimeout()调用。

setTimeout(function fn(){
    setTimeout(fn,interval);
},interval);

<b>这个模式链式调用了setTimeout(),每次函数执行的时候都会创建一个新的定时器。第二个setTimeout()调用当前执行的函数,并为其设置另外一个定时器。这样做的好处是,在前一个定时器代码执行完之前,不会向队列插入新的定时器代码,确保不会有任何缺失的间隔。而且,它可以保证在下一次定时器代码执行之前,至少要等待指定的间隔,避免了连续的运行。</b>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 定时器 参考链接 setTimeout() 上面代码的输出结果就是1,3,2,因为setTimeout指定第二行语...
    Cause_XL阅读 3,199评论 0 0
  • 高级定时器 关于定时器要记住的最重要的事情是:指定的时间间隔表示何时将定时器的代码添加到队列,而不是何时实际执行代...
    源境阅读 3,526评论 0 1
  • 9.26-9.30 第8章 驯服线程和定时器 定时器可以在js中使用,但它不是js的一项功能,如果我们在非浏览器环...
    如201608阅读 3,712评论 0 2
  • JavaScript提供定时执行代码的功能,叫做定时器(timer),主要由setTimeout()和setInt...
    晚晴幽草阅读 5,594评论 1 18
  • 曾经有人问我夜空中最亮的星是什么,我会毫不犹豫的说是启明星。但现在我的回答变了,夜空中最亮的星是我那一群可爱的同学...
    梦之绿阅读 3,483评论 1 3

友情链接更多精彩内容