一篇文章带你搞懂JavaScript 微任务(Microtask)

  发布时间:2025-11-05 13:34:25   作者:玩站小弟   我要评论
大家好,我进阶学习者。一、前言Promise 处理始终是异步的,因为所有 promise 行为都会通过内部的 “promise jobs” 队列,也被称为“微任务队列”。Promise 的处理程序(h 。

大家好,篇文我进阶学习者。章带

一、搞懂前言

Promise 处理始终是微任务异步的,因为所有 promise 行为都会通过内部的篇文 “promise jobs” 队列,也被称为“微任务队列”。章带

Promise 的搞懂处理程序(handlers).then、.catch 和 .finally 都是微任务异步的。

即便一个 promise 立即被 resolve,篇文.then、章带.catch 和 .finally ,搞懂下面的微任务代码也会在这些处理程序(handler)之前被执行。

代码如下:

let promise = Promise.resolve(); promise.then(() => alert("promise done!")); alert("code finished");  // 这个 alert 先显示 

如果运行它,篇文会首先看到 code finished,章带然后才是搞懂 promise done。这很奇怪,因为这个 promise 肯定是一开始就完成的。

运行结果:

为什么 .then 会在之后才被触发?这是怎么回事?

二、微任务队列(Microtask queue)

1. 如果执行顺序对很重要该怎么办?

Promise 的处理程序(handler)总是会经过这个内部队列。

如果有一个包含多个 .then/catch/finally 的链,高防服务器那么它们中的每一个都是异步执行的。也就是说,它会首先进入队列。

然后在当前代码执行完成并且先前排队的处理程序(handler)都完成时才会被执行。

2. 怎么才能让 code finished 在 promise done 之后运行呢?

很简单,只需要像下面这样使用 .then 将其放入队列:

Promise.resolve()   .then(() => alert("promise done!")); //规定相对应的顺序   .then(() => alert("code finished")); 

上面代码,加上这语句就是按照预期执行的。

三、未处理的 rejection

现在,可以确切地看到 JavaScript 是如何发现未处理的 rejection 的。

如果一个 promise 的 error 未被在微*任务*队列的末尾进行处理,则会出现“未处理的 rejection”。

正常来说。

如果预期可能会发生错误,会在 promise 链上添加 .catch 来处理 error:

let promise = Promise.reject(new Error("Promise Failed!")); promise.catch(err => alert(caught)); // 不会运行:error 已经被处理 window.addEventListener(unhandledrejection, event => alert(event.reason)); 

运行结果:

但是如果忘记添加 .catch,那么,微任务队列清空后,b2b信息网JavaScript 引擎会触发下面这事件:

let promise = Promise.reject(new Error("Promise Failed!")); // Promise Failed! window.addEventListener(unhandledrejection, event => alert(event.reason)); 

运行结果:

如果迟一点再处理这个 error 会怎样?

例:

let promise = Promise.reject(new Error("Promise Failed!")); setTimeout(() => promise.catch(err => alert(caught)), 1000); // Error: Promise Failed! window.addEventListener(unhandledrejection, event => alert(event.reason)); 

现在,如果运行上面这段代码,会先看到 Promise Failed!,然后才是 caught。

注:

如果并不了解微任务队列,可能会想:“为什么 unhandledrejection 处理程序(handler)会运行?已经捕获(catch)并处理了 error!”。

当微任务队列中的任务都完成时,才会生成 unhandledrejection:引擎会检查 promise,如果 promise 中的任意一个出现 “rejected” 状态,unhandledrejection 事件就会被触发。

在上面这个例子中,被添加到 setTimeout 中的 .catch 也会被触发。只是会在 unhandledrejection 事件出现之后才会被触发。

四、总结

本文基于JavaScript基础,介绍了微任务。其中.then/catch/finally 处理程序(handler),总是在当前代码完成后才会被调用。

如果需要确保一段代码,在 .then/catch/finally 之后被执行,可以将它添加到链式调用的 .then 中。

在大多数 JavaScript 引擎中(包括浏览器和 Node.js),微任务(microtask)的概念与“事件循环(event loop)”和“宏任务(macrotasks)”紧密相关。

代码很简单,希望能够帮助你更好的云服务器学习。

  • Tag:

相关文章

  • 电脑声卡应用程序错误的解决方法(遇到声卡应用程序错误怎么办?)

    摘要:在使用电脑过程中,我们经常会遇到一些问题,其中之一就是声卡应用程序错误。这个问题不仅会影响我们的音频体验,还可能导致无法正常使用电脑。本文将针对声卡应用程序错误提供一些解决方法,帮...
    2025-11-05
  • LPWAN技术有哪些

    随着物联网(IoT)的不断发展,对高效且具有成本效益的通信技术的需求变得更加明显,以支持越来越多的连接设备。应对这一挑战的一种解决方案是低功耗广域网(LPWAN)技术,它提供低功耗和最低基础设施要求的
    2025-11-05
  • 物联网智能医疗解决方案,为生活赋能

    物联网技术的爆炸性采用为网络技术的显着进步铺平了道路。专家们表示,到2025年,物联网(IoT)有可能带来令人惊叹的13万亿美元现金,这是一笔可观的收入!这个令人难以置信的数字让人们得以一窥整个医疗和
    2025-11-05
  • 数字孪生如何重新定义物联网和智能建筑

    探索数字孪生与物联网在智能建筑创新中的协同作用数字孪生正迅速成为物联网 (IoT) 和智能建筑领域的游戏规则改变者。 随着世界越来越多地接受数字化转型,数字孪生的概念越来越受欢迎
    2025-11-05
  • 打造纯净电脑系统的完全指南(一步步教你如何自己制作纯净高效的电脑系统)

    摘要:在使用电脑的过程中,我们经常会遇到系统卡顿、软件冲突等问题,这些都是由于系统中存在过多无用软件和插件所导致的。为了解决这些问题,我们可以自己动手制作一个纯净高效的电脑系统,本文将提...
    2025-11-05
  • 物联网如何帮助企业实现可持续发展和净零目标

    众所周知,物联网(IoT)是整个行业的游戏规则改变者。通过将设备和传感器连接到互联网,物联网实现了更高水平的自动化、效率和数据驱动的决策。那么物联网如何在企业实现可持续发展、净零排放目标方面发挥关键作
    2025-11-05

最新评论