Вы можете проверить content-type
ответ, как показано в этом примере MDN :
fetch(myRequest).then(response => {
const contentType = response.headers.get("content-type");
if (contentType && contentType.indexOf("application/json") !== -1) {
return response.json().then(data => {
});
} else {
return response.text().then(text => {
});
}
});
Если вам нужно быть абсолютно уверенным, что контент является допустимым JSON (и не доверяет заголовкам), вы всегда можете просто принять ответ как text
и самостоятельно проанализировать его:
fetch(myRequest)
.then(response => response.text())
.then(text => {
try {
const data = JSON.parse(text);
} catch(err) {
}
});
Асинхронный / ожидание
Если вы используете async/await
, вы можете написать его более линейно:
async function myFetch(myRequest) {
try {
const reponse = await fetch(myRequest);
const text = await response.text();
const data = JSON.parse(text);
} catch(err) {
}
}