覆盖后访问window.console

时间:2023-03-04
本文介绍了覆盖后访问window.console的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

console.log 被覆盖后是否可以通过某种方式访问​​它?

Is it possible to somehow access to console.log after it gets overwritten?

window.console = { log: function (msg) { alert(msg); }, /* etc... */ };

能否恢复原来的 console.log 功能?

Would be it be possible to regain the original console.log functionality?

推荐答案

您可以在覆盖之前备份控制台.

You can back up the console before overwriting it.

var oldConsole = window.console;
window.console = { log:function(msg){alert(msg)} //...};

然后你可以使用 oldConsole 变量.

Then you can use the oldConsole variable.

oldConsole.log('test');

如果无法备份,可以创建 iFrame,然后从那里窃取控制台(这可能不适用于所有浏览器):

If you can't back it up, you can create an iFrame, and then steal the console from there (this may not work in all browsers):

var i = document.createElement('iframe');
i.style.display = 'none';
document.body.appendChild(i);
window.console = i.contentWindow.console;

演示:http://jsfiddle.net/jcG7E/2

这篇关于覆盖后访问window.console的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

上一篇:避免 IE 抛出的常见习语:错误:'console' is u 下一篇:浏览器中的tail -f

相关文章

最新文章