【前端每天一题】🔥 第 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'

相关推荐
fanruitian20 小时前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo20 小时前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
RANCE_atttackkk20 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
2501_9445255421 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
Bella的成长园地21 小时前
面试中关于 c++ async 的高频面试问题有哪些?
c++·面试
李白你好1 天前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
Abona1 天前
C语言嵌入式全栈Demo
linux·c语言·面试
刘一说1 天前
Vue 组件不必要的重新渲染问题解析:为什么子组件总在“无故”刷新?
前端·javascript·vue.js
徐同保1 天前
React useRef 完全指南:在异步回调中访问最新的 props/state引言
前端·javascript·react.js
刘一说1 天前
Vue 导航守卫未生效问题解析:为什么路由守卫不执行或逻辑失效?
前端·javascript·vue.js