您推荐哪种解决方案,第二种更简单(代码更少),但使用它有缺点吗?
首先:(设置全局调试标志)
// the first line of code
var debug = true;
try {
console.log
} catch(e) {
if(e) {
debug=false;
}
};
// Then later in the code
if(debug) {
console.log(something);
}
第二名:覆盖console.log
try {
console.log
} catch(e) {
if (e) {
console.log = function() {}
}
};
// And all you need to do in the code is
console.log(something);
答案 0 :(得分:55)
既不是,也是第二种的变种。丢失try...catch
并正确检查控制台对象是否存在:
if (typeof console == "undefined") {
window.console = {
log: function () {}
};
}
console.log("whatever");
答案 1 :(得分:6)
或者,在coffeescript中:
window.console ?=
log:-> #patch so console.log() never causes error even in IE.
答案 2 :(得分:3)
编辑: Andy's answer比我在下面发布的快速黑客更优雅。
我通常使用这种方法......
// prevent console errors on browsers without firebug
if (!window.console) {
window.console = {};
window.console.log = function(){};
}
答案 3 :(得分:1)
我在过去遇到过类似的错误,我用下面的代码克服了它:
if(!window.console) {
var console = {
log : function(){},
warn : function(){},
error : function(){},
time : function(){},
timeEnd : function(){}
}
}
答案 4 :(得分:0)
我遇到过这篇文章,与其他答案类似:
http://jennyandlih.com/resolved-logging-firebug-console-breaks-ie
答案 5 :(得分:0)
以下内容将实现您的目标:
window.console && console.log('foo');
答案 6 :(得分:0)
window.console = window.console || {};
window.console.log = window.console.log || function() {};