私はJSON.parse
を時々404レスポンスを含むレスポンスに使っています。 404を返す場合、例外をキャッチしてから他のコードを実行する方法はありますか?
data = JSON.parse(response, function (key, value) {
var type;
if (value && typeof value === 'object') {
type = value.type;
if (typeof type === 'string' && typeof window[type] === 'function') {
return new(window[type])(value);
}
}
return value;
});
私は何かをiframeに投稿してからjson parseでiframeの内容を読み返す...だからjson文字列ではない場合もある
これを試して:
if(response) {
try {
a = JSON.parse(response);
} catch(e) {
alert(e); // error in the above string (in this case, yes)!
}
}
エラー&404 statusCodeをチェックしてtry {} catch (err) {}
を使うことができます。
これを試すことができます:
const req = new XMLHttpRequest();
req.onreadystatechange = function() {
if (req.status == 404) {
console.log("404");
return false;
}
if (!(req.readyState == 4 && req.status == 200))
return false;
const json = (function(raw) {
try {
return JSON.parse(raw);
} catch (err) {
return false;
}
})(req.responseText);
if (!json)
return false;
document.body.innerHTML = "Your city : " + json.city + "<br>Your isp : " + json.org;
};
req.open("GET", "https://ipapi.co/json/", true);
req.send();
続きを読む :
私はJavascriptについてはかなり新しいです。しかし、これは私が理解したことです。無効なJSONが最初のパラメーターとして指定されている場合、JSON.parse()
はSyntaxError
例外を返します。そう。次のように、その例外をキャッチすることをお勧めします。
try {
let sData = `
{
"id": "1",
"name": "UbuntuGod",
}
`;
console.log(JSON.parse(sData));
} catch (objError) {
if (objError instanceof SyntaxError) {
console.err(objError.name);
} else {
console.err(objError.message);
}
}
「最初のパラメータ」という語を太字にしたのは、JSON.parse()
が2番目のパラメータとして復活関数を取るからです。