ES11 全新的 Promise APIs: 中断错误投递

面试官:小伙子,你的数组去重方式惊艳到我了

引言

在前端开发中,处理异步代码是无法避免的过程,Promise 是一个常见的异步处理方式。但是在使用 Promise 的过程中,有时会遇到错误处理的问题。在 ES11 中,有全新的 Promise APIs 可以解决这个问题,那就是中断错误投递。

什么是中断错误投递?

中断错误投递是指在链式调用中,如果有错误发生,Promise 将停止向下传递错误,直到被试图 catch 这个错误或者调用新的 then 函数。在处理链式调用的过程中,这种特性非常有用。

以往我们会看到类似以下的代码:

--------------
-------- -- -
    ------ -----------------
--
-------- -- -
    --------------
--
------------ -- -
    -------------------
---

假设 anotherPromise 函数返回一个 reject 的 Promise,这时错误就会向下传递到 console.error(err)。如果错误的处理方式不是在这个位置处理,我们需要增加一些函数或者 try/catch 块到调用链中来处理这个错误。

在 ES11 中,我们可以使用 AggregateError 类型来解决这种情况。

--------------
-------- -- -
    ------ ---------------------------- -- - 
        ----- --- --------------------- ------ --- -- --------
    ---
--
-------- -- -
    --------------
--
---------------------- ----- -- -
    ---------------------------
    --- ------ - -- ----------- -
        ------------------ --------- ----- ----------- ---
    -
---

在这个例子中,我们向 anotherPromise 添加了一个 catch 调用并且将错误使用 AggregateError 包装起来。这就会导致 Promise 链停止在这里,直到新的 catch 调用,这里就是全新的 catch 函数,它可以为我们提供更多处理错误的灵活性。

深入学习:了解 AggregateError 类型

在 ES11 中,我们可以使用 AggregateError 类型来创建一个 Promise 的错误对象。这个对象包含一个错误的列表,可以使用 errors 属性来访问,并且可以添加一个可选的错误消息作为第二个参数来区分不同的 Promise 链。

在下面的例子中,我们使用 AggregateError 包装两个 Promise 链中的错误,以便我们更好地处理它们。

----- -------- ------------------ -
    --- -
        ----- - - ------------------ ----------------
        ----- - - ------------------ --------- -------
        ----- ------- - ----- ---------------------- ----
        ----- ------ - ----------------- ------ -- -- ------ --- ------------------ ------ -- -- --------
        -- -------------- - -- -
            ----- --- ---------------------- ----- ------ ------------
        -
    - ----- --- -
        ----------------------- -- ----- ------ ----------
        ---------------------- -- ------- ------ ------ -- ----
    -
-

------------------------------ -- ------------------

在这个例子中,我们首先创建了两个被 reject 的 Promise,然后使用 Promise.allSettled 来处理它们,并将结果筛选出 reject 的 Promise 并组成一个错误列表。如果有一个或多个错误,我们就抛出一个 AggregateError 类型的错误,并传递一个描述性的字符串作为它的第二个参数,以此来描述错误的类型。

指导意义

AggregateError 类型的出现使得在链式调用中处理错误变得更加容易。它的使用可以减少在调用链中添加额外错误处理函数的次数,并简化调用链的结构。同时,使用它也会给开发人员带来更多的灵活性和可读性。

结论

在 ES11 中,我们得到了更好的 Promise 错误处理的方法,即中断错误投递。这个特性的使用让我们在处理错误时更加方便和重构代码更加容易。用 AggregateError 类型可以更加灵活地处理错误,并让代码更加清晰明了。在实际的开发中,我们应该尽可能多地使用这个特性来提升我们的代码质量。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/66ef81676fbf9601972f90e5


猜你喜欢

  • Angular 8 入门:什么是依赖注入?

    在使用 Angular 进行开发的时候,依赖注入(Dependency Injection)是一个非常重要的概念。本文将介绍什么是依赖注入,为什么需要使用依赖注入,以及如何在 Angular 中使用依...

    25 天前
  • 如何将 ES6 代码转换为 ES8

    ES6 作为新一代的 JavaScript 标准,引入了许多新特性和语法,使得前端开发更加简洁、高效、可读性更强。但是有些浏览器不支持所有的 ES6 特性,因此需要将 ES6 代码转换为 ES5 代码...

    25 天前
  • 在 Redux 中使用 RxJS 进行响应式编程

    在 Redux 中使用 RxJS 进行响应式编程 Redux 是一个流行的 JavaScript 应用程序状态管理库。它的主要优点是可以跨应用程序传递数据,并且易于调试。

    25 天前
  • Mocha 测试套件中如何测试 WebSocket

    Mocha 测试套件中如何测试 WebSocket WebSocket 是一种网络通讯协议,它可以让浏览器和服务器之间建立一个持久化的双向通讯通道,使得 Web 应用程序可以在实时的基础上进行互动和控...

    25 天前
  • Next.js 应用中如何实现前端缓存?

    前言 缓存是 web 应用中一种有效的优化措施,减少重复请求的次数和响应时间,提升应用的性能。与后端缓存不同,前端缓存离用户更近,可以最大限度地减少请求时间和服务器负载。

    25 天前
  • 牛刀小试:Resets 和 Normalize.css 的性能分析

    牛刀小试:Resets 和 Normalize.css 的性能分析 前端开发中,Resets 和 Normalize.css 是非常常见的样式初始化方式。Resets 旨在对大量样式进行重置,而 No...

    25 天前
  • Web 无障碍性开发的 CSS 技巧

    许多人都会想到 Web 无障碍(Accessibility)的开发是优化 HTML 标签,如增加语义化标签、带名字和角色的表单元素等等,但是仅仅只做到这些仍有许多人因为使用 Web 的问题而无法得到完...

    25 天前
  • React 项目中使用 AntD Pro 的技巧

    在现代应用程序开发中,前端框架已经成为了每个项目的必需品。其中,React 是一个很流行的前端框架,它已经在很多大型和小型项目中得到了广泛的应用。而 AntD Pro 是一个基于 Ant Design...

    25 天前
  • Angular 和 RxJS:从初级到高级

    什么是 Angular 和 RxJS Angular 是一种基于 TypeScript 的开源 Web 应用框架,由 Google 开发和维护。Angular 提供了一些强大的功能,例如组件,指令,模...

    25 天前
  • 如何解决 Chai 的 expect 和 assert 在测试框架中报错的问题

    在前端开发中,测试是非常重要的一环。而 Chai 是一个非常流行的测试框架,可以用来编写 BDD 或 TDD 风格的测试代码。Chai 有两种语法风格,分别是 expect 和 assert。

    25 天前
  • Jest 测试框架:使用 Puppeteer 进行端到端测试的实现方法

    在前端开发中,测试是非常重要的环节之一。随着网站和应用程序愈发复杂,单元测试已经不足以满足测试需求。这时,端到端测试变得越来越重要。 Puppeteer 是一个基于 Node.js 的高度可用、基于 ...

    25 天前
  • 如何在 Laravel 项目中引入 Tailwind 框架

    Tailwind 框架是一种基于原子设计理念的 CSS 框架,它提供了大量可重复利用的 CSS 类,使得前端开发变得更加简单。而Laravel 是一种非常流行的 PHP 框架,在这篇文章中,我们将会介...

    25 天前
  • 在 React Native 中使用 Redux-Thunk 实现异步 Action

    随着移动应用开发的不断发展,React Native 已经成为了一种流行的开发框架。它提供了一种全新的开发方式,使得编写移动应用变得更加容易,同时也提供了更加强大的功能。

    25 天前
  • Custom Elements 如何使用加密技术保证数据安全?

    前言 在前端开发的过程中,我们时常需要处理用户数据,而这些数据可能包含一些敏感信息,如个人账户信息、支付信息等。为了保证这些数据的安全性和保密性,我们需要使用加密技术来保护用户数据。

    25 天前
  • 在 Deno 中使用 Elasticsearch

    Elasticsearch 是一款流行的搜索引擎,可用于存储、搜索和分析数据。在 Deno 中使用 Elasticsearch 可以方便地处理数据和提供搜索功能。本文将介绍如何在 Deno 中使用 E...

    25 天前
  • React 项目中的代码分割

    React 是一个非常强大的前端框架,通过其组件化的思想,使前端的开发更加容易和快捷。然而,随着项目的规模增加,JavaScript 文件的大小也会随之增加,导致应用程序加载速度变慢。

    25 天前
  • ES11 中的类型化函数和 BigInt

    ES11 是 JavaScript 新版本中的一个里程碑。其中包含很多重要的新特性,例如类型化函数和 BigInt。这两个特性为我们的开发过程带来了巨大的便利和优化,而且对于那些使用 JavaScri...

    25 天前
  • 如何在 Angular 应用中使用 Server-Sent Events

    如何在 Angular 应用中使用 Server-Sent Events 在 Web 应用程序中,对于实时数据的处理和交互,Server-Sent Events(SSE)成为一种常用的技术方案。

    25 天前
  • GraphQL 和 Apollo 的性能测试和优化

    简介 GraphQL 是一种跨平台、开源和查询语言,用于 API 的查询和数据操纵。它被设计为更加高效、强大和灵活的替代 REST API。Apollo 是一种针对 GraphQL 的前端框架,其目标...

    25 天前
  • NgRx 和 RxJS:使用 Observable 管理状态

    前端开发中,状态管理是一个非常重要的任务。它可以帮助我们跟踪应用程序的变化,并管理复杂的用户交互。NgRx 和 RxJS 是两个流行的 JavaScript 库,它们可以帮助我们以一种优雅、可组合和易...

    25 天前

相关推荐

    暂无文章