【前端每天一题】🔥 第 14 题:Promise.then 链式调用执行顺序

这道题是大厂面试常考题,核心考察对事件循环和微任务队列的理解。


✅ 第 14 题:Promise.then 链式调用执行顺序


📘 一、核心概念

  • Promise.then / catch / finally 回调都是微任务(microtask)
  • 微任务队列:当前宏任务执行完后立即执行所有微任务
  • 同步代码先执行 → 微任务 → 宏任务

📘 二、经典题目

javascript 复制代码
console.log('script start');

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

Promise.resolve().then(() => {
  console.log('promise1');
}).then(() => {
  console.log('promise2');
});

console.log('script end');

📘 三、详细分析(步步解析)

  1. 同步执行
arduino 复制代码
console.log('script start') // 输出 1
console.log('script end')   // 输出 2
  1. 微任务队列(Promise.then)
  • 第一个 then 回调 → 输出 'promise1'
  • 第二个 then 回调 → 输出 'promise2'
  1. 宏任务队列(setTimeout)
  • 输出 'setTimeout'

📘 四、最终输出顺序

arduino 复制代码
script start
script end
promise1
promise2
setTimeout

✅ 面试官非常喜欢问这个输出顺序。


📘 五、速记卡(10 秒复盘版)

javascript 复制代码
🎯 同步代码 > 微任务(Promise.then) > 宏任务(setTimeout/setInterval/IO)

🎯 Promise.then 内再 then → 链式微任务,依次执行

🎯 核心点:
- Promise.then 回调总是微任务
- 微任务会在当前宏任务结束后立即执行
- 微任务内部再生成微任务,会追加到队列末尾

📘 六、拓展题(加分)

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

输出顺序:

复制代码
1
3
2

解释:

  • '1' → 微任务队列第一个
  • setTimeout → 宏任务
  • 第二个 then → 微任务队列末尾,紧跟 '1' 执行
  • 宏任务最后执行 '2'

相关推荐
chxii13 小时前
在 IIS 中实现 SSL 证书的自动续期
前端
周星星日记13 小时前
vue3中静态提升和patchflag实现
前端·vue.js·面试
橘子编程13 小时前
React 19 全栈开发实战指南
前端·react.js·前端框架
DanCheOo13 小时前
AI Streaming 架构:从浏览器到服务端的全链路流式设计
前端·agent
我是小趴菜13 小时前
前端如何让图片、视频、pdf等文件在浏览器直接下载而非预览
前端
cg3314 小时前
开源项目自动化:用 GitHub Actions 让每个 Issue 都被温柔以待
前端
indexsunny14 小时前
互联网大厂Java面试实战:Spring Boot、MyBatis与Kafka在电商场景中的应用
java·spring boot·面试·kafka·mybatis·电商·技术栈
programhelp_14 小时前
字节跳动(ByteDance)2026 OA 面经|高频题型拆解 + 速通攻略
面试
haierccc14 小时前
Win7、2008R2、Win10、Win11使用FLASH的方法
前端·javascript·html
We་ct14 小时前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·