次のコードを使用して、ページ内のすべてのエラーを処理しようとしています。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
window.onerror = function (e, url, line) {
var data = '{"error":"' + e + '","line":"' + line + '","uri":"' + url + '","client":"' + navigator.appName + '","version":"' + navigator.userAgent + '"}';
var call = "http://myserver.com/sandbox/error.aspx?e=" + data;
var jse = document.createElement("script");
var head = document.getElementsByTagName("head")[0];
jse.setAttribute("type", "text/javascript");
jse.setAttribute("src", call);
head.appendChild(jse);
alert("fail");
return true;
}
</script>
</head>
<body>
<script type="text/javascript">
var b;
a = 5; //a is undefined
b = 5;
c = 8; //c is undefined
</script>
</body>
</html>
これは動作し、Internet Explorer 開発者ツール (F12) でリクエストを確認できます:
http://myserver.com/sandbox/jserror.aspx?e={"error":"'a' is undefined","line":"23","uri":"file:///C:/User/user/Desktop/Data/JSerror/javascript-error.htm","client":"Microsoft Internet Explorer","version":"Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0; SLCC2; .NET CLR 2.0.50727; .NET CLR 3.5.30729; .NET CLR 3.0.30729; .NET4.0C; .NET4.0E; Zune 4.7)"}
HTTP ステータスは 200 OK で、データはサーバーに配信されます。問題は、代わりにこれを行うと、最初のエラーのみが処理されることです:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript">
window.onerror = function (e, url, line) {
var data = '{"error":"' + e + '","line":"' + line + '","uri":"' + url + '","client":"' + navigator.appName + '","version":"' + navigator.userAgent + '"}';
var call = "http://myserver.com/sandbox/error.aspx?e=" + data;
var jse = document.createElement("script");
var head = document.getElementsByTagName("head")[0];
jse.setAttribute("type", "text/javascript");
jse.setAttribute("src", call);
head.appendChild(jse);
alert("fail");
return true;
}
</script>
</head>
<body>
<script type="text/javascript">
var b;
a = 5; //a is undefined
b = 5;
</script>
<script type="text/javascript">
c = 8; //c is undefined
</script>
</body>
</html>
次に、最初のスクリプト タグの最初のエラーと 2 番目のスクリプト タグの最初のエラーが処理されます。各スクリプト タグの最初のエラーだけでなく、すべてのエラーを処理したいと思います。
これは可能ですか?