您现在的位置是:亿华云 > 域名
在 promise 中 then 和 finally 有什么区别
亿华云2025-10-02 23:18:13【域名】0人已围观
简介看上去 promise.prototype.then() 和 promise.prototype.finally 似乎非常相似。但是你需要明白它们有一些重要的差异。第一个也最明显的是 finally(
看上去 promise.prototype.then() 和 promise.prototype.finally 似乎非常相似。区别但是区别你需要明白它们有一些重要的差异。
第一个也最明显的区别是 finally() 没有得到 promise 链的结果。由于 finally() 没有收到值,区别因此无法更改 promise 的区别已解决值。
new Promise((resolve,区别 reject) => resolve(10)) .then(x => { console.log(x); // 10 return x + 1; }) .finally(x => { console.log(x); // undefined return x + 2; }); // Promise resolves to 11, the return value of then()另一个差异与错误处理以及如何解决 promise 链有关。亿华云有时,区别您可能想要推迟捕获 promise 链中的区别错误,从而允许你在其他地方处理。区别在这种情况下,区别promise 链的区别 then() 将不会被执行,而 finally() 会。区别并且如果上一个 catch() 抛出,区别你最终会处于相同的区别情形之下。高防服务器
new Promise((resolve,区别 reject) => reject(0)) .catch(x => { console.log(x); // 0 throw x; }) .then(x => { console.log(x); // 将不会执行 }) .finally(() => { console.log(clean up); // clean up }); // Uncaught (in promise) 0这里的重点是,除非有非常特殊的原因,否则不应该替换 then() 和 finally()。 根据经验,finally() 应该用于清理(清除超时,使引用为空,重置 UI 状态等)。
云服务器提供商很赞哦!(6)