javascript题目,如何在重写alert后还能正常弹出alert
by 司徒正美
at 2012-02-03 09:21:00
original http://www.cnblogs.com/rubylouvre/archive/2012/02/03/2335946.html
今天在群里遇到一道很有意思的题目,大家发挥所能,给出的答案五花八门。特意整理成博文发表出来:
//原题目:
window.alert = function(){};______;alert(1); 填空,使后面的alert(1)能正确弹出,至少列举两种不同思路。
解法一,创建新的执行环境,使用iframe沙箱
window.alert = function(){};
window.alert=function(obj){
var iframe=document.createElement("iframe");
iframe.src="javascript:void(0);"
document.body.appendChild(iframe)
iframe.contentWindow.alert(obj);
}
alert(1)
解法二,创建新的执行环境,打开新窗口
window.alert = function(){};
window.alert = function(a){
window.open('','').alert(a)
//window.createPopup().document.parentWindow.alert(a) //IE only
}
alert(1);
解法三, 弄回原来的alert(IE下失败)
window.alert = function(){};
window.alert = function(a){
delete window.alert;
window.alert(a);
}
alert(1);
解法四,思路同三(IE下失败)
window.alert = function(){};
window.alert = function(a){
window.__proto__.alert.call(window,a);
//window.constructor.prototype.alert.call(window,a);
}
alert(1);
解法五(IE only)
window.alert = function(){};
execScript('sub alert(msg):msgbox msg:end sub', 'vbscript');
alert(1);
解法六,就是一晕招
window.alert = function(){};
window.alert = function(a){
window.confirm(a)
}
alert(1);