var users = [
{ user: "Name1",geo:{lat:'12',long:'13'} },
{ user: "Name2",geo:{lat:'12',long:'13'}, age: 2 },
{ user: "Name2",geo:{lat:'12',long:'13'} },
{ user: "Name3",geo:{lat:'12',long:'13'}, age: 4 }
];
Above is the array of objects.
Here is the for-loop
I destructured and get user and age but I want lat and long also how will I do that ? I want it through destructuring and for-loop
like I did with user and age
for (let { user, age = "DEFAULT AGE" } of users) {
console.log(user, age);
}
If you're just trying to find a given user and return the geo for it, this will do:
users.find( u => u.user === 'Name1' ).geo;
Keep in mind, you would want to do some checks aginst your 'find result' before trying to use it. For example:
You can use this:
You have already successfully destructured
user
(simply by the property name in the object) andage
(with a default value as well).To use nested destructuring, step by step, simply put the property name
geo
in there as well, since that’s the next property on the objects you’re iterating over that contains your needed values:{user, age = "DEFAULT AGE", geo}
— this would yield{lat: "12", long: "13"}
forgeo
.To access the nested properties directly, follow the object structure:
{user, age = "DEFAULT AGE", geo: {}}
— this would just validate thatgeo
is indeed an object.Then, list the properties you want to access in that object:
{user, age = "DEFAULT AGE", geo: {lat, long}}
— this would yield"12"
forlat
and"13"
forlong
.You could even go a step further and rename those properties:
{user, age = "DEFAULT AGE", geo: {lat: latitude, long: longitude}}
— this would yield"12"
forlatitude
and"13"
forlongitude
.These are the basic cases for destructuring objects:
name
means “just assign the entire value toname
”.{}
means “check that the value to be destructured is an object or can be converted into one, i.e. is neithernull
norundefined
; create no variables”.{ prop }
means “get the value ofprop
as the variableprop
”.{ prop: rename }
means “follow theprop
property and get its value as the variablerename
”1.{ prop = value }
means “get the value ofprop
as the variableprop
, but assignvalue
ifprop
yieldsundefined
”2.For the “rename” case, the rules apply recursively:
rename
is likename
, so it can be replaced by{}
, or{ anotherProp }
, or{ anotherProp: anotherRename }
, or{ anotherProp = anotherDefault }
, etc.Other properties on the same object level may be added via commas, like
{propA, propB}
.For arrays, similar cases exist:
[]
would validate that the value to be destructured is an iterable object;[a, b]
has the same meaning as{0: a, 1: b}
; etc.1: Note that in the case of
{ prop: something }
no variableprop
is created.2: “yields
undefined
” means thatobj.prop
would be equal toundefined
which means either that the property exists and has the literal valueundefined
or that the property doesn’t exist.