【发布时间】:2016-09-30 00:24:26
【问题描述】:
我最近一直在搞乱fetch() api,并注意到一些有点古怪的东西。
let url = "http://jsonplaceholder.typicode.com/posts/6";
let iterator = fetch(url);
iterator
.then(response => {
return {
data: response.json(),
status: response.status
}
})
.then(post => document.write(post.data));
;
post.data 返回一个Promise 对象。
http://jsbin.com/wofulo/2/edit?js,output
但是如果写成:
let url = "http://jsonplaceholder.typicode.com/posts/6";
let iterator = fetch(url);
iterator
.then(response => response.json())
.then(post => document.write(post.title));
;
post 这是一个标准的Object,您可以访问它的title 属性。
http://jsbin.com/wofulo/edit?js,output
所以我的问题是:为什么response.json 在对象字面量中返回一个promise,但如果刚刚返回则返回值?
【问题讨论】:
-
这很有意义,因为如果响应不是有效的 JSON,
response.json()承诺可能会被拒绝。 -
返回值是因为promise 已被解析并传递response.json() 中的值。现在该值在 then 方法中可用。
-
请注意,尽管方法被命名为 json(),但结果不是 JSON。它返回一个用 JavaScript 对象解析的 promise,该对象是将正文文本解析为 JSON 的结果。这个对象可以是任何可以用 JSON 表示的东西——一个对象、一个数组、一个字符串、一个数字……参考:developer.mozilla.org/en-US/docs/Web/API/Body/json
-
stackoverflow.com/a/65445674/470749 是迄今为止对我最有帮助的答案。
标签: javascript asynchronous promise fetch-api