javascript - 从 Fetch API 中提取 JSON

标签 javascript

我意识到之前已经回答了非常相似的问题,但我仍然觉得它是如何工作的非常困惑...

根据我的理解,promises 用于处理异步请求 - 这些 promises 本质上发回状态或“promise”,即稍后将交付 JSON 主体(或其他对象)。

我想了解的是我如何正确处理这些请求,以便在 JSON 正文准备好解析之前函数不会返回。

下面我试图简单地提取键“result”(它返回一个字符串“result”)并将其解析为另一个可以存储的变量,然后在我的代码中的其他地方使用。不幸的是,我的代码总是返回一个 [Object Promise],而不是提取的 JSON。我相信这是因为 response.json 也是一个 promise ......但是,我不明白我是如何摆脱“ promise 链”并返回一个我可以实际做某事的值。

谢谢你的建议,

async function name() {
    const response = await fetch('https://xxxxx.herokuapp.com/timespent', {});
    const json = await response.json();

    return json.result;
}

let varr = name();
console.log(varr)

最佳答案

因为你的函数是异步的,它总是返回一个 promise 。您需要使用等待结果。

阅读更多关于异步的信息 here

async function name() {
  const response = await fetch('https://mautargets.herokuapp.com/timespent', {});
  const json = await response.json();
  return json.result;
    }

async function result(){
  //await can only be called from inside of async function. So we need async function for await name()
  
  let varr = await name();
  console.log(varr)  // Success
}

result()

关于javascript - 从 Fetch API 中提取 JSON,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53957730/

相关文章:

javascript - 如何获取使 Angular 变脏的字段?

javascript - jQuery.get 从数据中读取值

javascript - moment.js 未在 Firefox 扩展中的 chart.js 之前加载

javascript - 如果您的网站访问者禁用了 JavaScript,您会怎么做?

java - GWT:如果未登录应用程序,静态 HTML 页面应重定向到 login.html

javascript - 我怎样才能真正捕获 JavaScript 中花括号之间的内容?

javascript - 如何在单次运行期间使用 karma test-runner 测试两个具有相同名称的不同类?

javascript - 双倍计时

javascript - 当使用 element.style = <some CSSStyleDeclaration> 使元素消失

javascript - 如何在 mousedown 事件上更改鼠标光标