Truthy and Falsy Values in Javascript
📣 Sponsor
In Javascript, things can be true
, or false
, but they can also be truthy
or falsy
. The concept of truthy
and falsy
are usually considered only in a boolean context, such as in an if..else
statement, but they also affect other parts of Javascript - for example, what is returned from the logical OR operator.
What does truthy and falsy mean in Javascript?
Something is considered falsy
in Javascript if it can be converted to false
. In the same way, something is truthy
simply if it is not considered falsy
. While falsy
may seem like a vague statement, it actually has a specific definition. The following values are considered falsy
:
false
0
or-0
or0n
- any empty string, i.e.
""
null
undefined
NaN
Similarly, anything that is not equal to these is considered truthy
, for example:
- any object, i.e.
{}
, or[]
. - any non-zero number
- any non-empty string
- any non
null
,undefined
, orNaN
value.
Use of truthy and falsy
truthy
and falsy
values have implications in Javascript logic. For example, anything that can be converted to truthy
in a boolean setting (such as if..else
) is converted to true
, and the same goes for falsy
statements.
For example, the following if
statement is true
, simply because "1"
is a truthy
statement:
if("1") {
console.log('ok');
}
If the statement instead said if(0)
, it would return false, since 0
is falsy
. As you get into Javascript, you’ll find references to truthy
and falsy
everywhere, so it’s good to familiarise yourself with the concept now.
More Tips and Tricks for Javascript
- Javascript Array Slice Method
- Future Javascript: Javascript Pipeline Operators
- Javascript Shallow Copies - what is a Shallow Copy?
- Changing HTML Classes and Attributes in Javascript
- How to check if a user has scrolled to the bottom of a page with vanilla Javascript
- Check if an Object Contains all Keys in Array in Javascript
- Generating a Sitemap with Node.JS and Javascript Automatically
- Javascript Objects Cheatsheet
- Javascript: Check if an Array is a Subset of Another Array
- How does the Javascript logical AND (&&) operator work?