Ответ 1
Ни один, а вариант второго. Потеряйте try...catch
и проверьте наличие объекта консоли должным образом:
if (typeof console == "undefined") {
window.console = {
log: function () {}
};
}
console.log("whatever");
Какое решение вы порекомендуете, второе проще (меньше кода), но есть недостатки в его использовании?
Сначала: (установите глобальный флаг отладки)
// 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);
Ни один, а вариант второго. Потеряйте try...catch
и проверьте наличие объекта консоли должным образом:
if (typeof console == "undefined") {
window.console = {
log: function () {}
};
}
console.log("whatever");
Или, в coffeescript:
window.console ?=
log:-> #patch so console.log() never causes error even in IE.
РЕДАКТИРОВАТЬ: Andy answer является более элегантным, чем быстрый хак, который я опубликовал ниже.
Я обычно использую этот подход...
// prevent console errors on browsers without firebug
if (!window.console) {
window.console = {};
window.console.log = function(){};
}
В прошлом я столкнулся с подобной ошибкой, и я преодолел ее с помощью кода ниже:
if(!window.console) {
var console = {
log : function(){},
warn : function(){},
error : function(){},
time : function(){},
timeEnd : function(){}
}
}
Я столкнулся с этим сообщением, которое похоже на другие ответы:
http://jennyandlih.com/resolved-logging-firebug-console-breaks-ie
Следующее выполнит то, что вы ищете:
window.console && console.log('foo');
window.console = window.console || {};
window.console.log = window.console.log || function() {};