一分钟了解下JavaScript中的宏任务与微任务

JavaScript中的宏任务(macro-task)和微任务(micro-task)是指异步任务的两种不同类型。它们的执行顺序是不同的,因此在编写异步代码时需要注意它们之间的区别。

宏任务 宏任务是指由浏览器之外的环境(如操作系统、浏览器事件等)触发的异步任务,例如:

  1. setTimeout
  2. setInterval
  3. Ajax请求
  4. UI事件(click、scroll等)
  5. setImmediate(Node.js)

在每轮事件循环中,会选择一个宏任务执行,并清空所有的微任务。执行完当前的宏任务后,检查是否有微任务需要执行,如果有,则立即执行所有的微任务。接着,再选择一个宏任务执行,以此类推。

微任务 微任务是指由JavaScript环境本身触发的异步任务,例如:

  1. Promise.then/catch/finally
  2. MutationObserver
  3. process.nextTick(Node.js)

在每个宏任务执行完毕之后,会立即执行所有的微任务,直到所有的微任务都执行完毕为止。如果在执行微任务的过程中又产生了新的微任务,也会立即执行它们,直到微任务队列为空为止。

需要注意的是,Promise.then/catch/finally中的回调函数属于微任务,但Promise的构造函数属于宏任务。

总之,JavaScript中的宏任务和微任务是异步代码的两种不同类型,它们的执行顺序是不同的。在编写异步代码时,需要了解它们之间的区别,以避免出现不必要的问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Walter Sun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值