亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

JS紅皮書解讀之延時器和定時器

標簽:
JavaScript

webp

0

注意区分执行时间和间隔时间
执行时间:定/延时器代码执行的时间
间隔时间:定/延时器设置每隔 xxxms 执行

一、延时器(setTimeout)
1.延时器(setTimeout)的工作方式是:当设定一个延时器是5s后进行时,并不代表它5s后就立即执行,只是代表它5s后会被加入队列,如果5s后,队列没有其他东西,那么延时器的代码会立即执行,否则会延迟执行。

因此,关于延时器最重要的一点是:指定的时间间隔(如设置5s后执行),表示何时将延时器加入到队列,而不是何时真正执行代码。

//经测试,下面这段不起作用,可能是被废弃了。
2.Firefox中的延时器的实现还能让开发者确定延时器过了多久才执行,需要传递一个实际执行的时间(actualTime)执行时间的间隔(specifiedTime)(如设置5s后执行)的差值(diff=actualTime-specifiedTime)

 document.querySelector('#btn1').=function () {      console.time()
      setTimeout(function (diff) {        if(diff>0){          //晚调用,因为actualTime大于specifiedTime
          console.log('时间差为'+diff)
        }else if(diff>0){          //早调用,因为actualTime小于specifiedTime
          console.log('时间差为'+diff)
        }else{          console.log('时间差为'+diff)

        }

      },1000)      console.timeEnd()
    }

二、定时器(setInterval)
1.定时器的一大特点是每隔一段时间(如每隔2s)就会执行,一直重复。这样有个问题:设定一个定时器a每隔2s执行一次,如果a执行的时间(executiveTime)大于时间间隔(2s),那么,第一次执行的a还没执行完第一次,就开始执行第二次了。

js巧妙地避免了这个问题——即等到定时器的代码执行完后,再去将定时器的代码加入到队列中,所以定时器代码加入队列的最小时间间隔即指定间隔(因为理想状态是是定时器的执行时间在时间间隔内完成)。

2.使用setInterval的问题
(1)某些间隔会被跳过——如设置每个1s执行一次,如果该定时器代码执行时间大于1s,或者正好等于1s,那么,相当于代码执行时间正好等于间隔时间,那么,这个间隔时间就被执行时间占据了,所以就没有了间隔时间即没有间隔。


webp

image.png

(2)多个定时器代码执行之间的间隔可能会比预期小
因为代码执行时间会长一点(因为队列并不总是空闲的,所以要排队等待执行),导致时间间隔变小。

解决:使用递归调用延时器,代替定时器

    setTimeout(function () {      //执行代码
      //xxxx
      //xxxx
      setTimeout(arguments.callee,1000)
    },1000)

arguments.callee的作用是获取当前执行函数的引用,并设置新的相同的延时器再来一次,即递归调用?。

好处不再赘述了,即解决了上面的两个问题 :)

实际遇到的问题.当js中的for循环遇到延时器或者定时器时需要注意的问题
https://blog.csdn.net/wxl1555/article/details/53719659
一定要保存 i !!!

(完)



作者:小进进不将就
链接:https://www.jianshu.com/p/b8f0b95c13f8


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消