エラーがすぐにスローされた場合、 Chrome 開発者コンソールはユーザー定義のエラー イベント リスナーを呼び出しません( Paul S.によるこの回答によると)。
「ジャストインタイム」でエラーをスローする:
> window.onerror = function () {console.log('error!');};
function () {console.log('error!');}
> throw new Error();
Error
延期されたエラーをスローする:
> window.setTimeout(function() {throw new Error()}, 0);
xxxx
error!
Uncaught Error
( xxxxは の特定の戻り値ですsetTimeout()
)
これは、Chrome Dev Console が何らかの形で内部動作を変更するという点に私を導いた元のコード スニペットです。
// #btn is a simple button
document.getElementById("btn").addEventListener("click", function () {
var script = document.createElement("script");
script.innerHTML = "window.onerror=function(){alert('An error occurred!');};throw new Error('42');";
document.head.appendChild(script);
});
このコードは、通常の HTML ファイルで実行されます。