【前端每天一题】 第 5 题:Promise.then 执行顺序深入题(微任务队列机制)

事件循环第 5 题:Promise.then 执行顺序深入题(微任务队列机制)

这是事件循环中最常考、最容易写错的一题之一。

🎯 面试题:下面这段代码的执行顺序是什么?为什么?

javascript 复制代码
Promise.resolve().then(() => {
  console.log(1)
  Promise.resolve().then(() => console.log(2))
})
console.log(3)

✅ 标准答案

输出顺序:

复制代码
3
1
2

✅ 详细解析(面试官最喜欢的回答)

第一步:同步任务先执行

同步代码只有:

javascript 复制代码
console.log(3)

所以第一个输出:

复制代码
3

第二步:微任务队列分析

(1) 首先有一个微任务:
javascript 复制代码
Promise.resolve().then(() => {...})

此时微任务队列:

css 复制代码
[ taskA ]

执行 taskA(也就是外层的 then 回调):

javascript 复制代码
console.log(1)
Promise.resolve().then(() => console.log(2))

所以现在输出:

复制代码
3
1
(2) taskA 内又创建了一个新的微任务

这段代码:

javascript 复制代码
Promise.resolve().then(() => console.log(2))

把另一个微任务加入队列:

css 复制代码
[ taskB ]

事件循环会继续执行此轮的所有微任务,所以执行:

复制代码
2

最终输出:

复制代码
3
1
2

📌 关键记忆点(速记卡)

🔶 速记 1:微任务是"批处理"执行的

  • 宏任务执行完后,所有微任务会连续执行
  • 微任务内部再创建的微任务,会排到队列末尾但仍在本轮执行

🔶 速记 2:Promise.then 永远是微任务

🔶 速记 3:执行顺序优先级

顺序永远是:

  1. 同步任务
  2. 本轮所有微任务
  3. 下一轮宏任务(如 setTimeout)
相关推荐
于慨1 天前
Lambda 表达式、方法引用(Method Reference)语法
java·前端·servlet
石小石Orz1 天前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
从前慢丶1 天前
前端交互规范(Web 端)
前端
CHU7290351 天前
便捷约玩,沉浸推理:线上剧本杀APP功能版块设计详解
前端·小程序
GISer_Jing1 天前
Page-agent MCP结构
前端·人工智能
王霸天1 天前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
小领航1 天前
用 Three.js + Vue 3 打造炫酷的 3D 行政地图可视化组件
前端·github
@大迁世界1 天前
2026年React大洗牌:React Hooks 将迎来重大升级
前端·javascript·react.js·前端框架·ecmascript
PieroPc1 天前
一个功能强大的 Web 端标签设计和打印工具,支持服务器端直接打印到局域网打印机。Fastapi + html
前端·html·fastapi
悟空瞎说1 天前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js