snippetjavascriptCritical
How to check if array is empty or does not exist?
Viewed 0 times
arrayemptyexisthowcheckdoesnot
Problem
What's the best way to check if an array is empty or does not exist?
Something like this?
Something like this?
if(array.length < 1 || array == undefined){
//empty
}Solution
You want to do the check for
Update
This answer is getting a fair amount of attention, so I'd like to point out that my original answer, more than anything else, addressed the wrong order of the conditions being evaluated in the question. In this sense, it fails to address several scenarios, such as
The foolproof approach
Taking some inspiration from the comments, below is what I currently consider to be the foolproof way to check whether an array is empty or does not exist. It also takes into account that the variable might not refer to an array, but to some other type of object with a
To break it down:
-
Note that this will also eliminate array-like objects, such as the
-
The
The pragmatic approach
In a lot of cases, the above might seem like overkill. Maybe you're using a higher order language like TypeScript that does most of the type-checking for you at compile-time, or you really don't care whether the object is actually an array, or just array-like.
In those cases, I tend to go for the following, more idiomatic JavaScript:
Or, more frequently, its inverse:
With the introduction of the optional chaining operator (Elvis operator) in ECMAScript 2020, this can be shortened even further:
Or the opposite:
undefined first. If you do it the other way round, it will generate an error if the array is undefined.if (array === undefined || array.length == 0) {
// array does not exist or is empty
}Update
This answer is getting a fair amount of attention, so I'd like to point out that my original answer, more than anything else, addressed the wrong order of the conditions being evaluated in the question. In this sense, it fails to address several scenarios, such as
null values, other types of objects with a length property, etc. It is also not very idiomatic JavaScript.The foolproof approach
Taking some inspiration from the comments, below is what I currently consider to be the foolproof way to check whether an array is empty or does not exist. It also takes into account that the variable might not refer to an array, but to some other type of object with a
length property.if (!Array.isArray(array) || !array.length) {
// array does not exist, is not an array, or is empty
// ⇒ do not attempt to process array
}To break it down:
-
Array.isArray(), unsurprisingly, checks whether its argument is an array. This weeds out values like null, undefined and anything else that is not an array.Note that this will also eliminate array-like objects, such as the
arguments object and DOM NodeList objects. Depending on your situation, this might not be the behavior you're after.-
The
array.length condition checks whether the variable's length property evaluates to a truthy value. Because the previous condition already established that we are indeed dealing with an array, more strict comparisons like array.length != 0 or array.length !== 0 are not required here.The pragmatic approach
In a lot of cases, the above might seem like overkill. Maybe you're using a higher order language like TypeScript that does most of the type-checking for you at compile-time, or you really don't care whether the object is actually an array, or just array-like.
In those cases, I tend to go for the following, more idiomatic JavaScript:
if (!array || !array.length) {
// array or array.length are falsy
// ⇒ do not attempt to process array
}Or, more frequently, its inverse:
if (array && array.length) {
// array and array.length are truthy
// ⇒ probably OK to process array
}With the introduction of the optional chaining operator (Elvis operator) in ECMAScript 2020, this can be shortened even further:
if (!array?.length) {
// array or array.length are falsy
// ⇒ do not attempt to process array
}Or the opposite:
if (array?.length) {
// array and array.length are truthy
// ⇒ probably OK to process array
}Code Snippets
if (array === undefined || array.length == 0) {
// array does not exist or is empty
}if (!Array.isArray(array) || !array.length) {
// array does not exist, is not an array, or is empty
// ⇒ do not attempt to process array
}if (!array || !array.length) {
// array or array.length are falsy
// ⇒ do not attempt to process array
}if (array && array.length) {
// array and array.length are truthy
// ⇒ probably OK to process array
}if (!array?.length) {
// array or array.length are falsy
// ⇒ do not attempt to process array
}Context
Stack Overflow Q#24403732, score: 1553
Revisions (0)
No revisions yet.