详细介绍 ECMAScript 2020:Promise.prototype.finally() 方法的使用

Promise 是在 JavaScript 中进行异步编程时非常常见的一种方式,而在 ES2020 中,我们迎来了 Promise.prototype.finally() 方法,它可以在一个 Promise 遇到 resolve 或 reject 后,不管 Promise 状态如何,都执行一次指定的回调方法。

用法

Promise.prototype.finally() 方法接受一个 callback 函数作为参数,并且该函数不接受任何参数。它可以在 Promise 执行之后的任何时候执行,无论 Promise 是成功还是失败。

示例代码:

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

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

输出:

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

深入理解

Promise.prototype.finally() 方法主要用于在一个 Promise 进入结束状态后,执行一个回调函数。这个回调函数会在 Promise 的状态变为 settled(fulfilled 或 rejected)后被调用,不管 Promise 是成功还是失败都会执行,而且它不会修改 Promise 的状态或值。

在我们常规的开发中,可能需要动态地添加或者删除 loader,或者类似操作,或者需要更新或者修整组件的属性等等,但是在这些操作之前或之后,我们需要一些清理的操作,比如重置标志位、清空缓存等等。此时就可以用到 Promise.prototype.finally() 方法来执行相关的清理操作。

注意事项

需要注意的是,Promise.prototype.finally() 方法并不会返回一个新的 Promise,而是返回原来的 Promise。而且它不会处理回调方法返回的结果,而是直接执行回调方法,如果该方法抛出错误,则会被下一个 catch 块捕获到。

我们需要保证回调方法是一个纯函数,没有任何副作用和操作状态对象。否则会影响程序的可维护和可调试性。

总结

在 ES2020 中,Promise.prototype.finally() 方法是一个非常方便且常用的新特性。它可以帮助我们在对 Promise 进行状态处理时,方便地做出一些清理和相关操作。同时我们还需要注意一些回调函数的使用细节,以保证程序的稳定和可维护性。

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


猜你喜欢

  • JavaScript 中 ES6: 解构赋值如何用于数组

    简介 在 JavaScript 中,解构赋值是一种方便快捷的语法,它可以让我们从数组或对象中提取出特定的数据,然后将它们赋值给变量。在 ES6 中,解构赋值得到了进一步的加强和改进,这篇文章主要介绍在...

    1 年前
  • Kubernetes 中的 PV 和 PVC

    在 Kubernetes 中,PV(Persistent Volume)和 PVC(Persistent Volume Claim)是两个非常重要的概念,它们用于提供持久化存储,并且是 Kuberne...

    1 年前
  • 如何使用 Node.js 实现微信支付?

    微信支付是一款非常流行的移动支付产品,随着移动互联网的发展,微信支付在国内的使用率越来越高。在电商、线下商家以及公益等领域,微信支付都被广泛使用。 本文将介绍如何使用 Node.js 实现微信支付,帮...

    1 年前
  • CSS Reset 与语义化 HTML 的配合使用

    前言 前端发展迅速,各种网站应用层出不穷,而其中关于 CSS 的话题也是层出不穷,其中一个比较受欢迎的话题就是 CSS Reset 与语义化 HTML 的配合使用。

    1 年前
  • Koa 教程分享:解决 “koa-static middleware not serving files” 问题

    Koa 是 Node.js 的一个非常流行的 web 框架,它的灵活性和可定制性让许多开发者爱不释手。在使用 Koa 进行 web 开发时,你可能会遇到 “koa-static middleware ...

    1 年前
  • Docker 中使用 Traefik 进行反向代理的配置指南

    在现代Web应用程序中,反向代理越来越重要。反向代理在Web服务器和应用程序之间充当中介角色,它可以通过将流量路由到不同的后端服务器和负载平衡来优化性能和可靠性。从更高的角度来看,反向代理还可以提供更...

    1 年前
  • 使用 Jest 测试框架测试 Express 如何等待异步请求

    前言 在前端开发中,测试是非常重要的一环。其中,我们需要对后端 API 进行测试来确保其功能的正确性。而对于一些异步请求接口的测试,我们需要使用一些工具来等待其完成,以便我们进行断言验证。

    1 年前
  • ES7 对 Unicode 正则表达式进行了增强

    随着互联网的发展,使用 Unicode 字符集来满足各种语言和文本需求的趋势越来越明显。在 JavaScript 中,正则表达式是一种常见的工具,用于匹配和处理字符串。

    1 年前
  • 终极解决 TypeScript 中的 “无法找到名称” 的问题

    终极解决 TypeScript 中的 “无法找到名称” 的问题 在日常的 TypeScript 开发中,我们经常会遇到一些代码中出现 “无法找到名称” 的情况,这种情况不仅会浪费我们大量的时间,也会给...

    1 年前
  • ES9 中实现不区分大小写的字符串比较(Implementing Case-Insensitive String Comparisons in ES9)

    在日常的前端开发中,字符串的比较是必不可少的操作。但是,在比较字符串时常常会出现大小写的问题,造成不必要的麻烦。为了解决这个问题,ES9新增了不区分大小写的字符串比较功能,下面我们就来详细了解一下。

    1 年前
  • SASS 中使用 @content 关键字在嵌套规则内插入样式

    SASS (Syntactically Awesome Stylesheets) 是一个 CSS 预处理器,它可以让我们写出更加简洁、优雅和可读性更高的样式表。其中一个强大的特性是嵌套规则,可以更好地...

    1 年前
  • 解决 Promise 嵌套重用错误的方案

    在前端开发中,Promise 是我们使用频率非常高的一个 API,它解决了回调地狱的问题,使得代码的可读性和可维护性大大提高。但是,在我们使用 Promise 的过程中,可能会遇到一些嵌套重用的问题,...

    1 年前
  • 如何在 Fastify 框架中使用 Redis 进行缓存管理?

    前言 随着 web 2.0 的高速发展,用户对网站的性能和体验要求越来越高,如何提高网站的响应速度和性能就成为了前端开发中不可忽视的重要问题。其中,使用缓存技术是提高网站性能的常见手段之一。

    1 年前
  • 使用 Vue.js 构建模板组件的技术手段与实现方法及遇到的问题解决机制

    什么是模板组件 模板组件是由 Vue.js 框架提供的一种引入 HTML 模板的机制,它将一个已经定义好的 HTML 模板转化为一个可重复使用并可以在 Vue.js 应用中使用的组件。

    1 年前
  • 响应式设计在使用 jQuery 的 APP 中的实践案例

    在如今的移动互联网领域,基于多平台和多设备响应式设计已成为必不可少的技术,而 jQuery 作为一款优秀的 JavaScript 库,在响应式设计中也扮演了非常重要的角色。

    1 年前
  • Sequelize 中关于使用模型定义中的 set 和 get 方法的详细教程

    Sequelize 是一种基于 Promise 的 Node.js ORM(对象关系映射),可用于 Postgres、MySQL、SQLite 和 Microsoft SQL Server 等多种关系...

    1 年前
  • Tailwind 框架中如何制作模态框

    前言 Tailwind CSS是一种基于原子类的CSS框架,可以使CSS的编写更加简单、快速。同时,Tailwind CSS还提供了一系列预定义的样式类,可以帮助我们快速实现特定样式的组件。

    1 年前
  • 构建 Vue.js 移动单页应用

    随着移动互联网的普及,移动端单页应用变得越来越流行。Vue.js 作为一款流行的前端框架,其也被广泛应用于构建移动单页应用。本文将介绍如何使用 Vue.js 构建移动单页应用,并提供示例代码供读者参考...

    1 年前
  • 使用 Mocha 和 Phantom.js 进行 Web 应用端对端测试

    Web 开发日新月异,前端技术更是更新换代,为了确保 Web 应用的稳定性和可靠性,端对端测试成为了越来越重要的一个环节。而 Mocha 和 Phantom.js 是目前比较流行的端对端测试工具之一,...

    1 年前
  • CSS Flexbox 实现商品列表的方法

    在前端界面设计中,商品列表是一个非常常见的部分。但是在不同的设计风格和页面需求中,商品列表的布局也需要灵活调整,以满足不同的需求。在这种情况下,CSS Flexbox 提供了一种非常简单和灵活的布局方...

    1 年前

相关推荐

    暂无文章