js переопределить console.log, если не определен - PullRequest
26 голосов
/ 22 сентября 2010

Какое решение вы рекомендуете, второе проще (меньше кода), но есть недостатки при его использовании?

Первое: (установить глобальный флаг отладки)

// 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);

Ответы [ 7 ]

55 голосов
/ 22 сентября 2010

Ни один, но вариант второй. Потеряйте try...catch и проверьте правильность существования консольного объекта:

if (typeof console == "undefined") {
    window.console = {
        log: function () {}
    };
}

console.log("whatever");
6 голосов
/ 13 мая 2011

Или в кофейном тексте:

window.console ?=
    log:-> #patch so console.log() never causes error even in IE.
3 голосов
/ 22 сентября 2010

РЕДАКТИРОВАТЬ: Ответ Энди гораздо элегантнее, чем быстрый взлом, который я опубликовал ниже.

Я обычно использую этот подход...

// prevent console errors on browsers without firebug
if (!window.console) {
    window.console = {};
    window.console.log = function(){};
}
1 голос
/ 17 июня 2014

В прошлом я сталкивался с подобной ошибкой и преодолел ее с помощью кода ниже:

if(!window.console) {
    var console = {
        log : function(){},
        warn : function(){},
        error : function(){},
        time : function(){},
        timeEnd : function(){}
    }
}
0 голосов
/ 18 июля 2013
window.console = window.console || {};
window.console.log = window.console.log || function() {};
0 голосов
/ 24 ноября 2012

Следующие вещи достигнут того, что вы ищете:

window.console && console.log('foo');
0 голосов
/ 20 июня 2012

Я наткнулся на этот пост, который похож на другие ответы:

http://jennyandlih.com/resolved-logging-firebug-console-breaks-ie

...