Javascript objects can be used as maps. The following all is valid code:
var x = {}; x.a = 1; x['b'] = 2; // the same as x.b = 2; x[3] = 3; // x.3 won't work, but this syntax works fine. Also, x[3] == x['3']. x['What, this works too?!?!?'] = 'Yup, it does!';
But today I tested another case which... seems to work, but raises some warning flags in my head because it looks... wrong:
x[null] = 42;
Now, it would be extremely cool if this worked as expected (I won't have to rewrite a bunch of code then), but can I rely on it? Or maybe this is just some undocumented behavior which just happens to work in all modern browsers but might as well cease working on the next release of Google Chrome?
Javascript null is a primitive type that has one value null. JavaScript uses the null value to represent a missing object. Use the strict equality operator ( === ) to check if a value is null . The typeof null returns 'object' , which is historical bug in JavaScript that may never be fixed.
The trap of null null might appear, often unexpectedly, in situations when you expect an object. Then if you try to extract a property from null , JavaScript throws an error. Because who variable is an empty string, the function returns null . When accessing message property from null , a TypeError error is thrown.
null is not an identifier for a property of the global object, like undefined can be. Instead, null expresses a lack of identification, indicating that a variable points to no object. In APIs, null is often retrieved in a place where an object can be expected but no object is relevant.
Null is not an object in JavaScript!
Anything between the property brackets is converted to a string. null
becomes "null"
, which is a valid property.
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