美文网首页海纳百川
宏任务(macrotask)/微任务(microtask)

宏任务(macrotask)/微任务(microtask)

作者: 凛冬已至_123 | 来源:发表于2019-09-27 10:05 被阅读0次

在ES6规范中,microtask称为jobs,macrotask称为task
Event Loop 执行顺序:

  • 首先执行同步代码,这属于宏任务
  • 当执行完所有同步代码后,执行栈为空,查询是否有异步代码需要执行
  • 执行所有微任务
  • 当执行完所有微任务后,如有必要会渲染页面
  • 然后开始下一轮 Event Loop,执行宏任务中的异步代码,也就是 setTimeout 中的回调函数

微任务包括 process.nextTickpromiseMutationObserver,其中 process.nextTick为 Node 独有。
宏任务包括scriptsetTimeoutsetIntervalsetImmediateI/OUI rendering
这里很多人会有个误区,认为微任务快于宏任务,其实是错误的。因为宏任务中包括了 script,浏览器会先执行一个宏任务,接下来有异步代码的话才会先执行微任务。

相关文章

网友评论

    本文标题:宏任务(macrotask)/微任务(microtask)

    本文链接:https://www.haomeiwen.com/subject/haajyctx.html