setTimeout(function(){}, 0);
生活随笔
收集整理的這篇文章主要介紹了
setTimeout(function(){}, 0);
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1 for (var i = 0; i < 3; i++) {
2 setTimeout(function() {
3 console.log(i);
4 }, 0);
5 console.log(i);
6 }
結果是:
0 1 2 3 3 3?
?
?
?分析:
1、在實踐中,setTimeout 會在其完成當前任何延遲事件的事件處理器的執行,以及完成文檔當前狀態更新后,告訴瀏覽器去啟用 setTimeout 內注冊的函數。
2、setTimeout是異步的。正確的理解setTimeout的方式(注冊事件):
有兩個參數,第一個參數是函數,第二參數是時間值。
調用setTimeout時,把函數參數,放到事件隊列中。等主程序運行完,再調用。
原題等價于:
1 var i = 0; 2 setTimeout(function() { 3 console.log(i); 4 }, 0); 5 console.log(i); 6 i++; 7 setTimeout(function() { 8 console.log(i); 9 }, 0); 10 console.log(i); 11 i++; 12 setTimeout(function() { 13 console.log(i); 14 }, 0); 15 console.log(i); 16 i++;?
因為setTimeout是注冊事件。根據前面的討論,可以都放在后面。
原題又等價于如下的寫法:
?
?
?
參考資料:【http://www.qdfuns.com/notes/17398/e8a1ce8f863e8b5abb530069b388a158/page/3.html#tagsbar】
轉載于:https://www.cnblogs.com/softwarefang/p/6611759.html
總結
以上是生活随笔為你收集整理的setTimeout(function(){}, 0);的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 关于Spring的事务Transacti
- 下一篇: html5做的太阳系