宏任务与微任务的本质区别是什么?

宏任务与微任务的本质区别是什么?是否可以理解为浏览器在达到调用条件时自动调用的是宏任务,自己编写代码触发调用的回调属于微任务

阅读 4.7k
2 个回答

本质就是单一层级的任务队列不够用,于是引入微任务队列来体现任务的优先级。

你可以理解成飞机检票登机,本来的规则是简单的排队,先到先登机。加入微任务就好像加入头等舱先检票的规则。头等舱队伍里只要有人,工作人员就先安排头等舱的登机,头等舱队伍里没人了,再转而处理经济舱的队列。每处理一个经济舱乘客,工作人员就要瞥一眼头等舱队伍是否有人来了,如果有人,就要转到头等舱这边先处理。直到头等舱这边队伍空了,才能再回过头来处理经济舱的乘客。

至于什么 API 注册的是宏任务,什么 API 会是微任务,你可以详细去查一下。

本质就是为了区分任务的优先级。

可以这样理解 只有promise是微任务(还有其他的不常用),其他的都是宏任务

有一个队列,js执行,点击事件,setTimeout都是往队列里推一条任务,这就是你说的宏任务

在每个宏任务执行完成后会调用:本轮被加入进去的微任务

然后下一个宏任务

console.log('task 1')

Promise.resolve().then(() => {
    console.log('task 1之后的微任务')
    setTimeout(() => {
      console.log('task 3')
    }, 0)
})

setTimeout(() => {
    console.log('task 2')
}, 0)

console.log('task 1 end')
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题