fetch()
Ostatnio bawiłem się z interfejsem API i zauważyłem coś, co było nieco dziwaczne.
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
zwraca Promise
obiekt.
http://jsbin.com/wofulo/2/edit?js,output
Jednak jeśli jest napisane jako:
let url = "http://jsonplaceholder.typicode.com/posts/6";
let iterator = fetch(url);
iterator
.then(response => response.json())
.then(post => document.write(post.title));
;
post
tutaj jest standard, do Object
którego można uzyskać dostęp do atrybutu tytułu.
http://jsbin.com/wofulo/edit?js,output
Moje pytanie brzmi: dlaczego response.json
zwraca obietnicę w literale obiektu, ale zwraca wartość, jeśli została zwrócona?
response.json()
obietnica może zostać odrzucona, jeśli odpowiedź nie jest poprawnym formatem JSON.