Sean Anderson
Sean Anderson

Reputation: 29301

Is there a way to log to console without breaking code under IE?

I'm trying to use console.log to put some logging into the javascript side of my program. I noticed, though, that unless the dev console is open in IE, JS basically stops working when it hits console.log. This is a pain... it means I have to remove all the logging whenever I want to do a production build.

Aside from the obvious:

function DoSafeConsoleLog( parameters )
{
    if ( !$.browser.msie )
    {
         console.log( parameters ); 
    }
}

is there a good way to log javascript that is friendly to all major browsers?

EDIT:

Well, after looking at the duplicate post (oops) as well as considering the answers here, I've gotta side with just checking for the existence of console before calling. Even though I am loathe to have the extra markup, I would rather not step on the feet of future programmers who might want to use Firebug Lite to debug my code.

Upvotes: 13

Views: 5092

Answers (6)

Ruwen
Ruwen

Reputation: 3178

I solved it by using the "fake console" described above, to prevent the script execution breaking. It is included only for InternetExplorer < 10. I include this in my html head:

<!--[if lte IE 10]>
  <script> if (typeof console === "undefined") console = { log: function() { } }; </script>
<![endif]-->

Upvotes: 0

Josh Knutson
Josh Knutson

Reputation: 325

I use this snippet myself

if (! ('console' in window) ) {
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() {};
}else {
/*if it exists but doesn't contain all the same methods....silly ie*/
var names = ['log', 'debug', 'info', 'warn', 'error', 'assert', 'dir', 'dirxml', 'group', 'groupEnd', 'time', 'timeEnd', 'count', 'trace', 'profile', 'profileEnd'];
for (var i = 0; i < names.length; ++i) if(!window.console[names[i]])window.console[names[i]] = function() {};
};

Upvotes: 1

Stijn Geukens
Stijn Geukens

Reputation: 15628

I'm using fauxconsole; I modified the css a bit so that it looks nicer but works very well.

Upvotes: 0

zzzzBov
zzzzBov

Reputation: 179086

IE has its own console, and you wont want to override console if you're using firebug lite. Just make sure that console exists when log gets called:

if (window.console) console.log('foo bar baz', fizz, buzz);

Better yet, use && to shortcut:

window.console && console.log('foo bar baz', fizz, buzz);

Upvotes: 9

fatnjazzy
fatnjazzy

Reputation: 6152

function log(log){
  try{
     console.log( log); 
  }catch(err){}
}

Upvotes: 0

SLaks
SLaks

Reputation: 887469

You can create a fake console:

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

Upvotes: 15

Related Questions