在 JavaScript 中,使用 async 函数进行异步操作时,返回的值通常是一个 promise 对象。当 promise 对象被解析时,它会包含所请求数据。然而,直接返回 promise 对象会导致 [Object promise] 的错误,因为试图将它当作普通字符串处理。
要正确取回字符串值,有以下方法:
.then 嵌套
立即学习“Java免费学习笔记(深入)”;
在 intotext 函数返回的 promise 对象上使用 .then 方法。在 .then 回调中,可以访问解析后的数据并赋值给所需的变量。例如:
intotext(ids).then(result => { console.log(result); // 结果将是返回的字符串 });
.async/await
在调用 intotext 函数的地方使用 async/await 语法。这允许你等待 promise 对象解析,并直接获取其值。例如:
const result = await intotext(ids); console.log(result); // 结果将是返回的字符串
.valueof
如果你必须在没有 .then 或 async/await 的情况下获得字符串值,可以使用 .valueof 方法。这将提取 promise 对象中保存的实际值。不过,请注意,使用 .valueof 可能导致错误,因为某些 promise 可能不具有可用的值。例如:
const result = intoText(ids).valueOf(); console.log(result); // 可能打印 "undefined" 或抛出错误