JavaScript Null Coalesce
In last article I talked about optional chaining which is incredibly useful when trying to access methods and properties on potentially null objects. In this article I want to talk about another amazing JavaScript feature for handling null/undefined and that is the null coalesce operator. You are probably familiar with the logical or operator (||
) for handling default values.
This code is flawed, though, since if options.tries
is 0 then the default value of 10 will be used since 0 is a falsey value. In order to fix this the following code must be used.
This code now will only use the default value if option.tries
is null or undefined. The only problem is this code is pretty clunky to write, so that is why the null coalesce operator was created.
What Is The Null Coalesce Operator
The null coalesce operator is a new operator in JavaScript that works very similar to the logical or operator, but it will check for null/undefined instead of falsey.
The above code uses the null coalesce operator (??
) to check if options.tries
is null or undefined. If options.tries
is null or undefined then it will evaluate the right side of the operator which is 10 so 10 will be returned. Here are a few examples of the null coalesce operator being used to emphasize how it works.
As you can see only the values of null or undefined will cause the right side of the null coalesce operator to be evaluated. Any other value, even if it is falsey, will cause the right side of the operator to never be evaluated or returned. Because of this, the null coalesce operator is incredibly useful when dealing with default values for variables since falsey values like 0 will not be overridden by the default value.
Using The Null Coalesce Operator With Logical Or/And
It is possible to use the null coalesce operator with other logical operators like AND (&&
) and OR (||
), but parenthesis must be used in order to specify the order in which the logical operators evaluate.
In the above example when no parenthesis are used an error is thrown since JavaScript is not sure what order to evaluate the operators. In the second example, though, the value 10 is returned since first 0 || null
is evaluated which returns null and then null ?? 10
is evaluated which returns 10.
Browser Support
With all great new JavaScript features the biggest thing to worry about is browser support. Unfortunately, the null coalesce operator has very little support outside of the newest browsers. At the time Being the null coalesce operator only has 48% support across browsers. Luckily, though, you can still use this operator by using tools like babel to transpile your JavaScript code so that older browsers can understand it.
Last updated
Was this helpful?