Looking under the hood in UnderscoreJS, I see:
_.isFunction = function(obj) {
return toString.call(obj) == '[object Function]';
};
_.isString = function(obj) {
return toString.call(obj) == '[object String]';
};
_.isNumber = function(obj) {
return toString.call(obj) == '[object Number]';
};
This seems like an odd choice. Why not just use typeof to determine whether a value is a string, function, or number? Is there a performance gain by using toString? Is typeof not supported by older browsers?
Well actually this is because it is faster to check the [[Class]]
by checking with toString
. Also there could be less mistakes, since toString gives you the exact Class ...
check this :
var fn = function() {
console.log(typeof(arguments)) // returns object
console.log(arguments.toString()) // returns object Arguments
}
You could see the benchmark for underscore typeof vs toString here :
http://jsperf.com/underscore-js-istype-alternatives
Also there are some github issues with better explaination :
https://github.com/documentcloud/underscore/pull/332
https://github.com/documentcloud/underscore/pull/321
EDIT 1 :
You could also check this great article :
http://javascriptweblog.wordpress.com/2011/08/08/fixing-the-javascript-typeof-operator/
drinchev's answer is partially correct. toString is currently much slower than using typeOf in most browsers. See the 7th revision of the test he posted which uses typeOf. Both are still very fast though so in most cases this performance difference won't be noticeable and the tradeoff is worth conforming to the specs better than duck typing / typeOf.
Underscore pull request 321 (that drinchev listed) has an in-depth discussion of the tradeoffs and why they decided to use toString.
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