宏任务与微任务的本质区别是什么?是否可以理解为浏览器在达到调用条件时自动调用的是宏任务,自己编写代码触发调用的回调属于微任务
可以这样理解 只有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')
13 回答13k 阅读
7 回答2.2k 阅读
5 回答1.5k 阅读
3 回答1.3k 阅读✓ 已解决
5 回答1.7k 阅读✓ 已解决
6 回答1.3k 阅读✓ 已解决
2 回答1.4k 阅读✓ 已解决
本质就是单一层级的任务队列不够用,于是引入微任务队列来体现任务的优先级。
你可以理解成飞机检票登机,本来的规则是简单的排队,先到先登机。加入微任务就好像加入头等舱先检票的规则。头等舱队伍里只要有人,工作人员就先安排头等舱的登机,头等舱队伍里没人了,再转而处理经济舱的队列。每处理一个经济舱乘客,工作人员就要瞥一眼头等舱队伍是否有人来了,如果有人,就要转到头等舱这边先处理。直到头等舱这边队伍空了,才能再回过头来处理经济舱的乘客。
至于什么 API 注册的是宏任务,什么 API 会是微任务,你可以详细去查一下。
本质就是为了区分任务的优先级。