13

【译】ES2018 新特性:Promise.prototype.finally()

 3 years ago
source link: https://blog.skrskrskrskr.com/article/%E3%80%90%E8%AF%91%E3%80%91ES2018%E6%96%B0%E7%89%B9%E6%80%A7%EF%BC%9APromise-prototype-finally/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
neoserver,ios ssh client

【译】ES2018 新特性:Promise.prototype.finally()

Jul 09 2018 前端

Jordan Harband 提出了 Promise.prototype.finally 这一章节的提案。

如何工作?

.finally() 这样用:

promise
.then(result => {···})
.catch(error => {···})
.finally(() => {···});

finally 的回调总是会被执行。作为比较:

  • then 的回调只有当 promise 为 fulfilled 时才会被执行。
  • catch 的回调只有当 promise 为 rejected,或者 then 的回调抛出一个异常,或者返回一个 rejected Promise 时,才会被执行。
    换句话说,下面的代码段:
    promise
    .finally(() => {
    «statements»
    });
promise
.then(
result => {
«statements»
return result;
},
error => {
«statements»
throw error;
}
);

最常见的使用案例类似于同步的 finally 分句:处理完某个资源后做些清理工作。不管是一切正常,还是出现了错误,这样的工作都是有必要的。
举个例子:

let connection;
db.open()
.then(conn => {
connection = conn;
return connection.select({ name: 'Jane' });
})
.then(result => {
// Process result
// Use `connection` to make more queries
})
···
.catch(error => {
// handle errors
})
.finally(() => {
connection.close();
});

.finally() 类似于同步代码中的 finally {}

同步代码里,try 语句分为三部分:try 分句,catch 分句和 finally 分句。
对比 Promise:

  • try 分句相当于调用一个基于 Promise 的函数或者 .then() 方法
  • catch 分句相当于 Promise 的 .catch() 方法
  • finally 分句相当于提案在 Promise 新引入的 .finally() 方法

然而,finally {} 可以 return 和 throw ,而在.finally() 回调里只能 throw, return 不起任何作用。这是因为这个方法不能区分显式返回和正常结束的回调。


原文:http://exploringjs.com/es2018-es2019/ch_promise-prototype-finally.html

JavaScript, 翻译

© Frank Xiong | Powered by Hexo & Lights | 站长统计


About Joyk


Aggregate valuable and interesting links.
Joyk means Joy of geeK