setTimeout(fn,0)的作用

hi,朋友們你見到過window.setTimeout(fn, 0)的代碼嗎?那該語句是什么作用呢?答:延時函數(shù)fn的執(zhí)行(ps 也就是把fn放入事件循環(huán)隊列,隊列是后進后出喲)。那在什么場合下需要延時執(zhí)行函數(shù)fn且時延參數(shù)為呢?

栗子:

<input type="text" onkeydown = "document.getElementById('a').innerHTML = 'input is:'+this.value;" />

<div id="a">input is:</div>

運行結(jié)果如下圖:

為什么輸入123,輸出的結(jié)果是12呢?

因為輸入3時所觸發(fā)的事件級聯(lián)中,keydown事件的順序先于給input對象value屬性賦值的默認事件,所以輸出結(jié)果慢了一拍。

針對此問題,解決方案為把onkeydown屬性值改為onkeydown="setTimeout(function(){document.getElementById('a').innerHTML= 'input is:'+this.value;},0)"即延遲keydown事件執(zhí)行。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 計時器setTimeout是我們經(jīng)常會用到的,它用于在指定的毫秒數(shù)后調(diào)用函數(shù)或計算表達式。 語法:setTimeo...
    TGCode閱讀 928評論 0 8
  • setInterval(function,milliseconds,param1,param2,...) code...
    你聽cmy1994閱讀 784評論 0 1
  • 1.JQuery 基礎(chǔ) 改變web開發(fā)人員創(chuàng)造搞交互性界面的方式。設(shè)計者無需花費時間糾纏JS復(fù)雜的高級特性。 1....
    LaBaby_閱讀 1,493評論 0 2
  • 1.JQuery 基礎(chǔ) 改變web開發(fā)人員創(chuàng)造搞交互性界面的方式。設(shè)計者無需花費時間糾纏JS復(fù)雜的高級特性。 1....
    LaBaby_閱讀 1,262評論 0 1
  • https://nodejs.org/api/documentation.html 工具模塊 Assert 測試 ...
    KeKeMars閱讀 6,597評論 0 6

友情鏈接更多精彩內(nèi)容