首页 >web前端 >js教程 >如何在 JavaScript 中访问 Promise 链的解析值?

如何在 JavaScript 中访问 Promise 链的解析值?

Susan Sarandon
Susan Sarandon原创
2025-01-04 13:40:391045浏览

How Do I Access the Resolved Value of a Promise Chain in JavaScript?

了解 Promise 链和值访问

在 Angular 等 JavaScript 框架中使用 Promise 时,您可能会遇到返回 Promise 的异步函数,就像 Angular 的 $q 文档中的示例一样:

promiseB = promiseA.then(function(result) {
  return result + 1;
});

虽然文档指出“promiseB将在promiseA解决后立即解决...promiseA的结果增加1”,可能不清楚这是如何工作的。

理解这一点的关键是要认识到这一点PromiseA 中的 then 函数返回一个新的 Promise,PromiseB。这个新的promise在promiseA解析后立即解析,它的值由promiseA中success函数的返回值决定。

在这种情况下,success函数返回“结果1”,所以promiseB将解析为result 的值增加 1。因此,要访问该值,您可以执行以下操作:

promiseB.then(function(result) {
    // Here you can use the result of promiseB
});

在现代 JavaScript 版本(ES7 及更高版本)中,您可以使用使用 async/await 语法来实现相同的功能:

async function doSomething() {
    let result = await functionThatReturnsPromiseA();
    return result + 1;
}

在这种情况下,await 解开 PromiseA 的结果并将其直接分配给结果变量,允许您在不访问 Promise 的情况下使用该值object.

请注意,async/await 只能在始终返回 Promise 的异步函数中使用。因此,如果要访问异步函数的返回值,则必须在另一个异步上下文中使用await。

以上是如何在 JavaScript 中访问 Promise 链的解析值?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn