等待与返回 Promise:了解等待与 Promise 返回
简介:
在 JavaScript 中,可以使用 Promise 来处理异步任务。在处理异步函数中的 Promise 时,会出现一个常见的困境:应该使用 return等待 Promise 还是简单地返回 Promise?本文探讨了这两种方法之间的差异,重点介绍了它们的行为细微差别和错误处理影响。
行为和性能:
一般来说,没有显着差异在使用 return等待承诺和返回承诺之间的可观察行为中。两种方法都会产生相同的预期结果,并且性能差异可以忽略不计。然而,由于可能创建中间 Promise 对象,该实现可能会稍微偏向 return wait 版本。
错误处理:
当 return 或return wait 在 try-catch 块中使用。让我们考虑一下代码片段:
async function rejectionWithReturnAwait () { try { return await Promise.reject(new Error()) } catch (e) { return 'Saved!' } } async function rejectionWithReturn () { try { return Promise.reject(new Error()) } catch (e) { return 'Saved!' } }
在rejectionWithReturnAwait中,异步函数在返回其结果之前等待被拒绝的promise。这会触发一个异常,该异常被 catch 子句捕获,导致函数返回一个解析为“已保存!”的 Promise。
相比之下,rejectionWithReturn 直接返回被拒绝的 Promise,而无需在异步函数中等待它。因此,catch 情况不会被调用,并且 Promise 拒绝会传播给调用者。
结论:
在大多数情况下,都会返回等待承诺和返回承诺产生相同的行为。但是,当 try-catch 块中涉及错误处理时,return await Promise 可确保等待 Promise 并由封闭函数捕获异常,而 return Promise 则直接返回 Promise,而不在函数内进行错误处理。
以上是Await 与 Promise Return:在错误处理中应该使用哪个?的详细内容。更多信息请关注PHP中文网其他相关文章!