微任务和宏任务

在JavaScript中,任务分为两种类型:微任务和宏任务。

微任务是在当前任务执行完成后立即执行的任务,例如Promise回调、MutationObserver回调等。微任务的执行优先级高于宏任务。

宏任务是在当前任务执行完成后,等待一定时间后再执行的任务,例如setTimeout回调、setInterval回调、事件回调等。

在任务队列中,微任务排在宏任务之前执行。

例如以下代码:

复制代码
console.log("start");

setTimeout(() => {
  console.log("setTimeout");
}, 0);

Promise.resolve().then(() => {
  console.log("promise");
});

console.log("end");

输出的结果为:

复制代码
start
end
promise
setTimeout

原因是先执行同步代码输出start和end,然后遇到微任务,执行Promise回调输出promise,最后执行宏任务输出setTimeout。

相关推荐
忆江南2 分钟前
HTTP 各版本演进与 HTTPS 原理详解
前端
忆江南4 分钟前
对组件化与模块化的思考与总结
前端
小码哥_常9 分钟前
从0到1:Android组件化架构搭建秘籍
前端
忆江南9 分钟前
iOS 应用启动流程与优化详解
前端
itslife13 分钟前
前端架构模式思考
前端·架构
Wect19 分钟前
JSX & ReactElement 核心解析
前端·react.js·面试
雨落Re19 分钟前
从递归组件到 DSL 引擎:我造了一个让 AI 能"搭 UI"的运行时
前端·vue.js
Maxkim20 分钟前
前端工程化落地指南:pnpm workspace + Monorepo 核心用法与实践
前端·javascript·架构
大漠_w3cpluscom29 分钟前
使用 clip-path: shape() 创建 Squircle 形状
前端·css·weui
大怪v12 小时前
AI抢饭?前端佬:我要验牌!
前端·人工智能·程序员