17
Accessing Object Properties in JavaScript
Almost all JavaScript values have properties and accessing the said properties can be done in 3 ways, i.e.,
- dot notation
- square brackets
- object destructuring
To access a property of an object through dot notation, we must know the property name beforehand.
Syntax: expression.identifier
Let's see an example to understand this better.
Example 1:
const items = {
food: "soup",
"phone-1": "iphone 12"
}
// to access food property
items.food
// output => soup
In the example above, items
is an object from which we need to access a property, and food
is an identifier. Accessing food property of items is easy enough. However, if we try to access the phone-1
property through dot notation, it won't work. Wondering why? Because it is not a valid identifier. So, how can we access that property? We'll cover that in the next section.
Now you know how accessing a property from dot notation works.
Note: The identifier should be a valid identifier.
To access a property of an object via square brackets, we do not need to know the property name beforehand, that is, the property name could be dynamic (determined at run time).
Syntax: expression[expression]
Let's understand this method through example 1. In example 1, there was an object items
and it had two properties. So, to access the food
property, we simply have to do this: items[food]
. Now about that second property, do you think we would be able to access that?
If your answer is yes then you are correct.
We can access the phone-1
property by doing this: items["phone-1"]
. When using square brackets, the expression between the brackets is evaluated and converted to a string to get the property name. Whereas using dot notations only fetches the value.
Destructuring is a JavaScript expression that allows us to extract data from arrays, objects, and maps and set them into new, distinct variables. Object destructuring assigns the properties of an object to variables with the same names by default.
See the example below: -
Example 2:
const items = {
food: "soup"
"phone-1": "iphone 12"
}
const { food } = items;
food;
// output => soup
The destructuring defines a variable food
with the value of property food
.
Note: The variable should have the same name as the property.
Further, to create a variable name different than the property name and to access the phone-1
property, we can use aliasing.
Syntax: const { identifier: aliasIdentifier } = expression;
For instance in example 2, to create a different variable name of phone-1
property, do this:
const {"phone-1": newVariable} = items
newVariable;
// output => iphone 12
To access a property of an object via dot notation, the property name should be a valid identifier and known ahead of time. Whereas accessing the property of an object via square brackets is favorable when the property name is dynamic or is not a valid identifier. In addition, the object destructuring extracts the property directly into a variable.
Fun fact from Eloquent
The elements in an array are stored as the array’s properties, using numbers as property names. Because you can’t use the dot notation with numbers and usually want to use a binding that holds the index anyway, you have to use the bracket notation to get at them.
Did you like this blog? Let me know in the comments below✌️.
17