If you look at the ECMAScript 3 specification you will see that primitive value types Null and Undefined don't have accompanying Null and Undefined Objects.
>> Null ReferenceError: Null is not defined The other primitive value types Number, String and Boolean types do have accompanying Number, String and Boolean objects which you can reference from global scope.
>>Number function Number() { [native code] } >>Boolean function Boolean() { [native code] } The purpose for these primitive value types is to provide methods such as toString and valueOf for their respective primitive value types:
>>var n = 1; >>n.toString(); "1" is the same as
>>var n = 1; >>Number.prototype.toString.call(n); "1" Booleans and strings also work that way:
>>var b = true; >>b.toString(); "true" >>Boolean.prototype.toString.call(b); "true" You can see that the primitive value objects are using the methods of their accompanying object when you try to mix types:
>>Boolean.prototype.toString.call(n); TypeError: Boolean.prototype.toString is not generic >>Number.prototype.toString.call(b) TypeError: Number.prototype.toString is not generic Interestingly enough for boolean and string literal types, you can call these methods directly from the literal:
>>true.toString(); "true" >>Boolean.prototype.toString.call(true) "true" >>"moo".toString(); "moo" >>String.prototype.toString.call("moo") "moo" Primitive values null and undefined, since they don't have accompanying Null and Undefined objects cannot do these things:
>>Null ReferenceError: Null is not defined >>null.toString() TypeError: Cannot call method 'toString' of null Primitive value type number behaves like a mix of the two. You can call toString on a literal if you directly use the Number's prototype object's method:
>>Number.prototype.toString.call(1); "1" But you cannot access the method from the literal itself like you can with strings and booleans:
>>1.toString() SyntaxError: Unexpected token ILLEGAL Why is it that number literals behave differently from boolean and string even though there's a Number object?
A numeric literal is a character-string whose characters are selected from the digits 0 through 9, a sign character (+ or -), and the decimal point. If the literal contains no decimal point, it is an integer.
A decimal integer literal is a sequence of digits without a leading 0 (zero). A leading 0 (zero) on an integer literal, or a leading 0o (or 0O ) indicates it is in octal. Octal integer literals can include only the digits 0 – 7 . A leading 0x (or 0X ) indicates a hexadecimal integer literal.
You can access it the same way, it's a different parsing issue here, to do it, use a slightly different syntax:
(1).toString() Numbers can have decimals, so the syntax for ending in a decimal is a bit ambiguous when you go to parse the code, use parenthesis to be valid. It's a bit clearer when you see that this is also valid:
(1.).toString() However with just 1.toString() it's trying to parse as a number with a decimal, and it fails.
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