一个 promise的函数 已经使用await 在等待结果了 为什么还是会直接return 返回pending状态

发布于 2022-09-12 04:02:50 字数 633 浏览 27 评论 0

问题描述

一个 promise的函数 已经使用await 在等待结果了 为什么还是会直接return 返回pending状态

问题出现的环境背景及自己尝试过哪些方法

为什么在c的函数体中一定要加await才能在3秒后输出内容,加上await不应该同步等待aa执行完成之后才return么?

如果c不加async.await,则会打印出pending状态的promise

相关代码



function aa() {

return new Promise((resolve, reject) => {

setTimeout(() => {

resolve('wwee')

}, 3000)

})

}

const b = async() => {

let w = await aa()

console.log(w) //这时候是3秒打印内容

return w

}

const c = async() => {

console.log(await b())

}

c()

你期待的结果是什么?实际看到的错误信息又是什么?

自己想的应该是等待3秒之后才会return出结果,但是直接返回了一个promise的pending状态,感觉很奇怪,有什么办法可以解决么?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

阿楠 2022-09-19 04:02:50

async修饰的函数,返回值会自动转为promise。它是同步执行的,如果内部有await,会在await全部执行完后,返回的promise状态才会改变。

对你有帮助的话,请点个采纳给个赞,谢谢。

忘年祭陌 2022-09-19 04:02:50

const b = await async() => {...}

不能 await 就在外面再包一层 async

书间行客 2022-09-19 04:02:50

async 使返回类型就是为 Promise

按照你的代码只能

c().then(r => {
    // r
});

// 或者直接使用 then 调用 b()
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文