I\'ve been writing JavaScript for quite a long time now, and I have never had a reason to use null
. It seems that undefined
is always preferable an
At the end of the day, because both null
and undefined
coerce to the same value (Boolean(undefined) === false && Boolean(null) === false
), you can technically use either to get the job done. However, there is right way, IMO.
Leave the usage of undefined
to the JavaScript compiler.
undefined
is used to describe variables that do not point to a reference. It is something that the JS compiler will take care for you. At compile time the JS engine will set the value of all hoisted variables to undefined
. As the engine steps through the code and values becomes available the engine will assign respective values to respective variables. For those variables for whom it did not find values, the variables would continue to maintain a reference to the primitive undefined
.
Only use null if you explicitly want to denote the value of a variable as having "no value".
As @com2gz states: null
is used to define something programmatically empty. undefined
is meant to say that the reference is not existing. A null
value has a defined reference to "nothing". If you are calling a non-existing property of an object, then you will get undefined
. If I would make that property intentionally empty, then it must be null
so you know that it's on purpose.
TLDR; Don't use the undefined
primitive. It's a value that the JS compiler will automatically set for you when you declare variables without assignment or if you try to access properties of objects for which there is no reference. On the other hand, use null
if and only if you intentionally want a variable to have "no value".
I never explicitly set anything to undefined (and I haven't come across this in the many codebases I've interacted with). Also, I rarely use null
. The only times I use null
is when I want to denote the value of an argument to a function as having no value, i.e.,:
function printArguments(a,b) {
console.log(a,b);
}
printArguments(null, " hello") // logs: null hello