Javascript.RU

Функция ведения логов

Мне немного надоело везде писать if (console && console.log) { ... } и я написал небольшую оберточку:

var log = function () {
	/*	Кушаем крайний аргумент, в котором
	лежит loglevel текущего сообщения	*/
	var loglevel = Array.prototype.pop.call(arguments);

	if (typeof console !== 'undefined' &&
		console.log &&
		((loglevel & log.level) !== 0)) {
		console.log.apply(console, arguments);
	}
};

log.levels = {
	template: 1,
	call: 2
};

/*	выводить в лог только сообщения
с флагом log.levels.call	*/
log.level = log.levels.call;
-1

Автор: Koc, дата: 11 октября, 2010 - 19:49
#permalink
if (!("console" in window) || !("firebug" in console))
{
    var names = ["log", "debug", "info", "warn", "error", "assert", "dir", "dirxml",
    "group", "groupEnd", "time", "timeEnd", "count", "trace", "profile", "profileEnd"];

    window.console = {};
    for (var i = 0; i < names.length; ++i)
        window.console[names[i]] = function() {}
}

не?


Автор: ixth, дата: 11 октября, 2010 - 23:51
#permalink

Не. У меня не заглушка, а функция, которая выводит сообщения в консоль (если она есть) в зависимости от флага, который я передаю последним параметрам. Хочу — вывожу только логи с флагом log.levels.call, а хочу — только с log.levels.templates.


Автор: CTAPbIu_MABP (не зарегистрирован), дата: 12 октября, 2010 - 15:06
#permalink

я тоже такое делал
http://mabp.kiev.ua/2009/01/05/console2/


 
Поиск по сайту
Другие записи этого автора
ixth
Содержание

Учебник javascript

Основные элементы языка

Сундучок с инструментами

Интерфейсы

Все об AJAX

Оптимизация

Разное

Дерево всех статей

Популярные таги
Последние темы на форуме
Forum