await返回之后的赋值给一个变量可以打印出数值,但是直接return回去之后,在另一个函数打印出来却是一个promise

🧪 现象描述

你说:

await 返回之后赋值给一个变量可以打印出数值,但是 return 回去之后,在另一个函数打印出来却是一个 Promise

这是完全正常的,原因在于:使用了 await 的函数本身返回的是一个 Promise


🔍 示例说明

示例 1:你在 async 函数中用 await

javascript 复制代码
js
深色版本
async function getData() {
  const res = await fetchSomeData(); // 假设 fetchSomeData 返回一个 Promise
  console.log(res); // 这里能正常输出数据,比如 "Hello"
  return res;       // 注意这里 return 的值会被包装成 Promise
}

当你调用这个函数时:

ini 复制代码
js
深色版本
const result = getData();
console.log(result); // 输出: Promise { <pending> }

为什么会这样?

➡️ 因为 只要是 async 函数,它的返回值永远是一个 Promise


✅ 如何获取 async 函数返回的真实值?

你需要再用 .then() 或者在另一个 async 函数中用 await 来取值。

方法一:用 .then

ini 复制代码
js
深色版本
getData().then(data => {
  console.log(data); // 这里才是真正的数据,比如 "Hello"
});

方法二:在另一个 async 函数中用 await

javascript 复制代码
js
深色版本
async function useData() {
  const data = await getData();
  console.log(data); // 这里才是真正的数据
}

📌 关键点总结

内容 说明
await 的作用 暂停当前异步函数执行,直到 Promise resolve,并取出其值
async 函数的返回值 永远是一个 Promise,即使你 return 123,也会变成 Promise.resolve(123)
如果直接 return res 其实就是把 res 包装成一个 resolved 的 Promise
所以你看到的 Promise 是正常的 你需要继续用 .then()await 取出里面的值

🧠 举个完整例子

javascript 复制代码
js
深色版本
function fetchSomeData() {
  return new Promise((resolve) => {
    setTimeout(() => resolve("Hello"), 1000);
  });
}

async function getData() {
  const res = await fetchSomeData();
  return res; // 相当于 Promise.resolve("Hello")
}

// ❌ 错误方式:直接打印 async 函数结果
console.log(getData()); // Promise { <pending> }

// ✅ 正确方式 1:用 .then()
getData().then(data => console.log(data)); // 输出 Hello

// ✅ 正确方式 2:在 async 函数中 await
async function main() {
  const data = await getData();
  console.log(data); // 输出 Hello
}

main();

🚫 常见误区

  • ❌ 认为 return res 就可以直接拿到原始值
  • ❌ 在外部试图同步访问异步函数的结果(这不可能)

✅ 最佳实践建议

  • 使用 async/await 时,始终保持"链式异步",不要试图"同步化"异步操作。
  • 如果你在某个函数中用了 await,那这个函数应该也标记为 async
  • 要想拿到最终值,必须通过 .then() 或嵌套的 await
相关推荐
2301_801252226 小时前
前端框架Vue(Vue 的挂载点与 data 数据对象)
java·前端·javascript·vue.js·前端框架
资讯第一线6 小时前
《Windows Server 2022》 [2025年10月版 ] [官方IOS] 下载
前端
非凡ghost6 小时前
EaseUS Fixo(易我视频照片修复)
前端·javascript·后端
非凡ghost6 小时前
Avast Cleanup安卓版(手机清理优化)
前端·javascript·后端
豆苗学前端6 小时前
长时间不操作自动退出登录(系统非活跃状态下自动登出机制的企业级设计方案)
前端·后端·面试
一乐小哥6 小时前
用 AI 搞出 Chrome 版 “飞书 Command+K”!Figma AI 救了我的审美
前端·ai编程
非凡ghost6 小时前
Atlantis Word Processor(文字处理软件)
前端·javascript·后端
小时前端6 小时前
面试官:线上应用内存持续泄漏,你如何快速定位并止血?
前端·浏览器
前端白袍6 小时前
Vue:关于 Vue2 父子组件传值方法 以及 props 的定义方法和使用
前端·javascript·vue.js
非凡ghost6 小时前
TeamViewer 手机版:一键远程控制,深度管理,提升多设备管理效率
前端·javascript·后端