Letâs take a look at data type fundamentals in JavaScript!
By the end of the article, youâll have an increased understanding of working with many of the major data types. Which is a fundamental skill to pickup, as you move forward with JavaScript.
What are Data Types?
Data types are classifications of specific types of data. We have numbers, Booleans (true or false), strings (character sequences enclosed in quotes ââ
 or ââ
) and more complex data types known as arrays and objects (weâll look at these a bit later).
let a = 1; // a is a number
let a = "Avocado"; // a is a string
let a = true; // a is a Boolean
let a; // a is undefined
For example, a
, has been defined as a variable using the let
 keyword. We can assign any data type to it, or even just initialize it by leaving it blank.
Why Does it matter?
When storing data in a variable, itâs important that we know its type, as that determines what we can do with it! For instance, you can add numbers 1 + 1 = 2
, and thatâs fine. However, if you attempt to add numbers when they have the data type of string â1â + â1â = 11
 Your result will be 1 and 1, not the sum equaling 2 as you may have expected. Let's now take a look at each type in detail.
Numbers
Numbers in JavaScript can be written with or without decimals, such as:
let a = 1;
let b = 1.1;
And they can be abbreviated using the e
 exponent, for example:
let million = 1000000;
// or..
let million = 1e6;
The 6 is the amount of 0âs, which in this case equals one million.
There are a few special values that we often encounter when working with numbers, Infinity
, -Infinity
 and NaN.
If you attempt to divide a number by 0, such as:
3/0 // Infinity
The result will be Infinity. As the JavaScript computes the result outside its largest possible number of 9007199254740992
. The opposite would yield:
-3/0 // -Infinity
The value of NaN
 represents âNot a Numberâ, meaning the value isnât considered a number. This would generate in illegal expressions, such as:
let a = 100 / "Greg"; // a will be NaN
As of course you canât divide a number by a string!
However, JavaScript is smart enough to convert your data type in some cases, such as:
let a = 100 / "2" // a will be 50
JavaScript will use type coercion to consider your â2â string to be a number in this case.
Strings
As mentioned earlier, strings are sequences of characters that exist within either single or double quotes:
let foodChoice = 'Crunchy cheddar jalapeno cheetos';
let foodChoice = "Crunchy cheddar jalapeno cheetos";
Strings arenât limited to letters either, numbers and symbols are also acceptable. Itâs the quotes that define our string data type.
It really comes down to personal preference as to whether you use single or double quotes, consistency is whatâs most important within your code!
let eater = âBruceâ;
let foodChoice = "Crunchy cheddar jalapeno cheetos";
alert(eater + " loves " + foodChoice + "!")
// Bruce loves Crunchy cheddar jalapeno cheetos!
Booleans
We use the keywords true
 and false
 to set variables as Boolean data type.
let a = true;
let b = false;
Booleans are especially useful when performing mathematical operations, in determining whether an expression is true or false, such as:
10 > 5 // true, 10 is greater than 5
5 > 10 // false, 5 is not greater than 10
5 < 10 // true, 5 is less than 10
5 = 5 // true, 5 equals 5
If we assign our expression to a variable, such as:
let a = 10 > 5; // true
Our variable a
 will of course, hold the value of true.
Booleans are used within programs when we need to perform operations based on the evaluation of truth or falsehood. For example, do the received login credentials evaluate to true? Grant access âď¸. Or are they false? Deny access â.
Arrays
An array is a slightly more complex data type, however they are really quite simple to grasp! An array is a way to have multiple values held by a single variable. For example:
let colors = ["red", "green", "blue", "yellow"]
An array is defined by using square brackets []
 as in the above example. Weâve assigned an array to the variable colors
, contained within are our elements of red, green, blue and yellow.
A call to our colors
 variable will output our entire array of [âredâ, âgreenâ, âblueâ, âyellowâ]
.
The true power of arrays is that their contents can be iterated, we can call out a single item within the array variable. To do this we use an index number, inside of square brackets:
colors[0] // red
colors[1] // green
colors[2] // blue
colors[3] // yellow
colors[4] // undefined
Note:Â Our first array element always has the index position of 0. So remember to start counting from 0 instead of 1!
Arrays have a large amount of flexibility, they can have elements added, removed and changed. Letâs now take a look at our final data type: objects!
Objects
The object data type is typically used for holding large amounts of related data. Object data values are stored in key/value pairs, the pairs make for a logical way to store and access our data, using curly braces {}
, for example:
let user = {firstName:"Jane", lastName:"Doe", age:34, location:"Vancouver"};
For clarity weâd write this out over multiple lines:
let user = {
firstName: "Jane",
lastName: "Doe",
age: 34,
location: "Vancouver"
};
Our above example contains four properties firstName
, lastName
, age
, and location
. Our properties can be of any data type, which are accessed using objectName.property as follows:
user.firstName // Jane
user.lastName // Doe
user.age // 34
user.location // Vancouver
Conclusion
Understanding how we classify data types is a fundamental skill to posses when moving forward with JavaScript. In this article, we looked at and what distinguishes each type.
Stay tuned for my next post, where we'll expand upon this knowledge by learning how to perform data type conversions.
Related Posts:
A little about me..
Hey, Iâm Tim! đ
Iâm a freelance business owner, web developer & author. I teach both new and experienced freelancers how to build a sustainable and successful freelancing business. Check out my Complete Guide to Freelancing if you'd like to find out more.
While you're here, you can browse through my blogs where I post freelancing tips, code tutorials, design inspiration, useful tools & resources, and much more! You can also join the newsletter, or find me on X.
Thanks for reading! đ