天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

認識延遲時間為0的setTimeout

讓我們看看我之前的文章:JavaScript的9個陷阱及評點,在第 9 點 Focus Pocus 中提到的問題。原作者對這個認識有所偏差,其實不只是 IE 的問題,而是現有 JavaScript 引擎對于線程實現的問題(關于線程,我的概念其實不多,如果不對,希望讀者多多指教)。. 我們來看 1 和 2。如果你能看看源代碼,會發現我們的任務很簡單,就是給文檔增加一個 input 文本框,并聚焦和選中。請現在分別點擊一下,可以看到,1 并沒有能夠聚焦和選中,而 2 可以。它們之間的區別在于,在執行:

input.focus();
input.select();
時, 2 多了一個延遲時間為 0 的 setTimeout 的外圍函數,即:

setTimeout(function(){
 input.focus();
 input.select();
}, 0);
按照 JavaScript: The Definitive Guide 5th 的 14.1 所說:

在實踐中,setTimeout 會在其完成當前任何延宕事件的事件處理器的執行,以及完成文檔當前狀態更新后,告訴瀏覽器去啟用 setTimeout 內注冊的函數。

其實,這是一個把需要執行的任務從隊列中跳脫的技巧。回到前面的例子,JavaScript 引擎在執行 onkeypress 時,由于沒有多線程的同步執行,不可能同時去處理剛創建元素的 focus 和 select 事件,由于這兩個事件都不在隊列中,在完成 onkeypress 后,JavaScript 引擎已經丟棄了這兩個事件,正如你看到的例子 1 的情況。而在例子 2 中,由于setTimeout可以把任務從某個隊列中跳脫成為新隊列,因而能夠得到期望的結果。

這才是延遲事件為 0 的setTimeout的真正目的。在此,你可以看看例子 3,它的任務是實時更新輸入的文本,現在請試試,你會發現預覽區域總是落后一拍,比如你輸 a, 預覽區并沒有出現 a, 在緊接輸入 b 時, a 才不慌不忙地出現。其實我們是有辦法讓預覽區跟輸入框同步地,在此我沒有給出答案,因為上面所說的,就是解決思路,try it yourself! 

JavaScript技術認識延遲時間為0的setTimeout,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲视频中文字幕在线 | 国产午夜视频在永久在线观看 | 酒色.com| 日韩亚洲中文欧美在线 | 无码国产精品高潮久久9 | 久久精品国产福利电影网 | 亚洲精品免费观看 | 恋夜影院支持安卓视频美女 | 亚洲成年人影院 | WWW亚洲精品久久久无码 | 久久精品AV无码亚洲色欲 | 在线观看国产区 | 免费观看美女的网站 | 久久麻豆亚洲AV成人无码国产 | 人人做人人干 | 日本国产成人精品无码区在线网站 | 大咪咪dvd| 国产剧情麻豆mv | 92看看福利午夜影院 | 伊人久久大香线蕉观看 | 国产精品成人啪精品视频免费观看 | 九九热精品免费观看 | 一本道mw高清码二区三区 | 欧美 另类 美腿 亚洲 无码 | 欧美精品一区二区三区视频 | 亚洲国产免费观看视频 | 国产久久re6免费热在线 | 久久欧洲AV无码精品色午夜麻豆 | 日本久久高清视频 | 兽交白浆喷水高潮 | 国产99网站 | 忘忧草秋观看未满十八 | 国产精品嫩草久久久久 | 幻女FREE性俄罗斯学生 | 国产久爱青草视频在线观看 | 一级黄色香蕉视频 | 男人私gay挠脚心vk视频 | 狠狠色狠狠色综合日日2019 | 国产探花在线精品一区二区 | 午夜在线观看免费完整直播网 | 被六个男人躁到一夜同性 |