Considering that console wasn't overriden and refers to native object, console.log method (and possibly others) is extracted from console object with
var log = obj.log = console.log;
// instead of console.log.bind(console)
log(...);
obj.log(...);
Is it 100% safe in terms of browser and Node compatibility?
A significant amount of JS examples (maybe too illustrative) with bound console.log suggests that it may be not.
Browsers differ in their console implementations, it appears that WebKit/Blink-based browsers (Chrome, Opera 15+, Safari, etc) are the only ones that are uncomfortable with extracted console methods. For browser compatibility extracted methods have to be bound:
var log = console.log.bind(console);
Node has its own console implementation that relies on this but pre-binds its methods. It is safe to extract console methods in Node applications, the same applies to Electron's main process.
NW.js replaces Node console with Chromium's:
Node.js and Chromium each has its own implementation of setTimeout and console. Currently, for console, we use Chromium's implementation everywhere, because it can print in devtools and have more information exposed.
It is not safe to extract console methods in NW.js Node's context.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With