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
相关推荐
遇见你...20 小时前
TypeScript
前端·javascript·typescript
Highcharts.js20 小时前
Highcharts Grid 中文站正式上线:表格数据处理的全新选择
前端·javascript·数据库·表格数据·highcharts·可视化图表·企业级图表
懂懂tty1 天前
CRA 迁移 Rspack(实战)
前端·架构
小码哥_常1 天前
Kotlin 助力 Android 启动“大提速”
前端
GreenTea1 天前
AI 时代,工程师的不可替代性在哪里
前端·人工智能·后端
Jagger_1 天前
能不能别再弄低代码害人了
前端
朦胧之1 天前
AI 编程开发思维
前端·后端·ai编程
踩着两条虫1 天前
VTJ:快速开始
前端·低代码·架构
木斯佳1 天前
前端八股文面经大全:携程前端一面(2026-04-17)·面经深度解析
前端·状态模式
Java后端的Ai之路1 天前
LangChain ReAct Agent 核心技术问答
前端·react.js·langchain