了解 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中文网其他相关文章!