您的位置:首页 > Web前端 > JavaScript

ie的新版本js的window.onerror.caller.caller最终总是指向自身导致死环

2013-04-09 21:09 204 查看
--------测试代码-----------
<html>
<title></title>
<body>
<textarea id="test">
出错代码;
</textarea>
<input type="button" onclick="try{window.execScript(test.value,'javascript');}catch(e){} " value = '运行输入框中js代码'/>
<script>

window.onerror = function(sMessage,sUrl,sLine)
{
var str = window.err_t + "出错了!\n\n";
if (window.err_t == '初始化页面时') str += "在文件[ " + sUrl + " ]";
str += "第" + sLine + "行\n" + sMessage + "\n\n";
var func = window.onerror.caller;
var index = 0;

while(func!=null){
str += "[" + index + "] 调用时参数/函数\n";
for(var i=0;i<func.arguments.length;i++) str += func.arguments[i] + ",";
str += "\n" + func + "\n\n";

if (func === func.caller) {
break;//在ie6中不必检测,但是后面版本可能有问题
}

func = func.caller;
index++;
//alert(func.caller);//去掉上面的断点即可发现最后总是指向自己
}

alert(str);
return true;
}
</script>
</body>
</html>

----------------------区别------
这个代码我当时是在ie6的情况下写的.
当时window.onerror.caller子对象的子对象是不会重复的.
而在ie9的测试中,我发现这个代码是死环.好像ie8是没有问题.

--------在ie6中这个检测是没必要加的--------
if (func === func.caller) {
break;//在ie6中不必检测,但是后面版本可能有问题
}

这说明js新版本对某些机制进行修改了.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: