promise.then在event loop中的执行顺序?

发布于 2022-09-13 01:03:46 字数 538 浏览 24 评论 0

有关JS事件循环,发现了以往认知外的情况:

代码

console.log("script start");

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

Promise.resolve()
  .then(function () {
    console.log("promise1");
  })
  .then(function () {
    console.log("promise2");
  });

Promise.resolve().then(function () {
  console.log("promise3");
});

console.log("script end");

结果:

script start
script end
promise1
promise3
promise2
setTimeout

问题

那三个promise.then中的log的顺序为什么不是1、2、3?而是1、3、2?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

意犹 2022-09-20 01:03:46

1、script start
2、把setTimeout添加到宏任务
3、Promise.resolve().then,把promise1添加到微任务
4、Promise.resolve().then,把promise3添加到微任务
5、script end
6、promise1,把promise2添加到微任务
7、promise3
8、promise2

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文