js是一門單線程的編程語言茄靠,也就是說js在處理任務(wù)的時候暮屡,所有任務(wù)只能在一個線程上排隊被執(zhí)行掺出,那如果某一個任務(wù)耗時比較長呢?總不能等到它執(zhí)行結(jié)束再去執(zhí)行下一個惭等。
所以在線程之內(nèi)珍手,又被分為了兩個隊列:
同步任務(wù)隊列
異步任務(wù)隊列
這里說的異步任務(wù)隊列是包含了獨立于主執(zhí)行棧之外的宏任務(wù)和微任務(wù)兩個隊列。其中宏任務(wù)包括:定時器辞做、ajax請求琳要、dom事件;微任務(wù)包括:Promise.then秤茅、MutationObserver(html5新特性)焙蹭。
如何理解JS事件循環(huán)機制:
事件循環(huán)是JS處理異步函數(shù)的方法,其中涉及到JS執(zhí)行棧嫂伞、宿主環(huán)境的其他線程(瀏覽器的其他線程web API)、事件隊列拯钻。首先執(zhí)行執(zhí)行棧中的代碼帖努,遇到異步任務(wù)時將代碼交給瀏覽器的其他線程處理,當(dāng)執(zhí)行棧中的所有代碼全部執(zhí)行完畢時粪般,在從事件隊列中取出第一個任務(wù)放入執(zhí)行棧拼余。然后重復(fù)循環(huán)。當(dāng)執(zhí)行棧清空時亩歹,JS引擎首先將微任務(wù)中的所有任務(wù)依次執(zhí)行結(jié)束后匙监,再執(zhí)行宏任務(wù)凡橱。
下面給出一個栗子具體分析:
打印結(jié)果:C E D A B
1.首先setTimeout A加入到宏任務(wù)隊列中
2.當(dāng)執(zhí)行obj.func()時setTimeout B加入到宏任務(wù)隊列中
3.返回的Promise函數(shù)中首次打印C,執(zhí)行resolve()時回調(diào)then方法中的函數(shù)亭姥,D放入微隊列首位
4.繼續(xù)執(zhí)行稼钩,控制臺第二次打印E
5.按照任務(wù)隊列的執(zhí)行順序依次打印D、A达罗、B
參考文章:https://www.qdskill.com/javascript/8429.html