婷婷震惊!你不是我之前认识的“宏任务”

今天看某vue中nextTick的某篇博客时,其中经常提到事件循环机制,之前面试也经常被问到,所以点进了该niubility博主解释循环机制的博客。原来。。。。

宏任务并不是同步任务啊!!!之前一直理解错了。

在事件循环机制中,首先在调用栈中执行主线程上的所有同步任务。此时web API会对异步任务进行操作,将处理后的回调函数放到任务队列中。然鹅!会根据任务类型,放入macrotask Queue(宏任务队列)或microtask(微任务队列)中。对于宏任务队列中的每一个任务,都在不同的事件循环中进行,而对于微任务队列中的所有任务,都在一次时间循环中进行。

也就是说,调用栈清空后,主线程查询微任务队列,执行清空;主线程再查询宏任务队列,取出队首任务进行执行,此时产生的微任务又放入微任务队列中。执行完后,再次查询微任务队列并清空,如此循环。。。

再总结下宏任务和微任务都有哪些:

宏任务:

在浏览器和node中都存在的:I/O、setTimeout、setInterval

浏览器中独有:requestAnimationFrame

node中独有:setImmediate

微任务:

在浏览器和node中都存在的:promise.then、catch、finally

浏览器中独有:MutationObserver

node中独有:process.nextTick

--------------------------------------------------------------------------介是一条分割线(看得出来吧!)-------------------------------------------------------------------------------------------------------------------

posted @ 2020-05-24 10:03  ashen1999  阅读(126)  评论(0编辑  收藏  举报