xxxxxxxxxx
const person = {
name: 'Arif',
age: 22,
job: 'we-developer',
friendList: ['abir', 'adnan', 'alvi'],
companyDetails: {
id: 3343,
companyName: 'IT solution',
salary: 33400,
location: 'jahanbarge',
}
}
const [x, y, z] = person.friendList;
console.log(x, y, z);
//Expected output:abir adnan alvi
xxxxxxxxxx
const a = {
id: 1,
name: 'Yogesh',
age: 30,
education: {
degree: 'Bachelor'
}
};
const {education: {degree}} = a;
console.log(degree); //prints: Bachelor
xxxxxxxxxx
// Destructuring an object > array > object structure
const returnedObject = {
docsArray: [
{socketRoom: '', routes: []},
{socketRoom: '', routes: []},
{socketRoom: '', routes: []},
]
}
// this will destructure the first and second elements from docsArray, and spread the remainder
const {docsArray: [element0, element1, remainder]} = returnedObject
// taking this further with destructing properties from element0
const {docsArray: [{socketRoom0, routes0} = element0, {socketRoom1, routes1} = element1]} = returnedObject
// note the syntax for destructing Objects and Arrays
const {propName} = Object
const [element0, element1] = Array
// then one layer deep where Object[propName] is an Array
const {propName: [element0]} = Object
// then two layers, where element0 is an Object
const {propName: [{propName} = element0]}
// three layers
const {propName: [{propName: [element00]} = element0]}
xxxxxxxxxx
const person = {
name: 'labib',
age: 22,
job: 'web-developer',
frieds: ['ahsik', 'abir', 'alvi', 'hanafi'],
childList: {
firstChild: 'Salman',
secondChild: 'Rafi',
thirdChild: 'Anfi'
}
}
const { frieds: [a, b, c] } = person; //array destructuring from a nested object
console.log(a, b, c);
//expected output: ahsik abir alvi;
const { childList: { firstChild, secondChild } } = person; //object destructuring from a nested object
console.log(firstChild, secondChild)
//expected output:Salman Rafi
xxxxxxxxxx
var personsInfo = {
company: 'sp-coder',
persons: [{
id: 1,
name: 'Adil',
friedsList: {
friend1: 'Nabil',
friend2: 'Habib'
}
}, {
id: 2,
name: 'Arif',
friedsList: {
friend1: 'alvi',
friend2: 'avi'
}
}]
};
const { friend1, friend2 } = personsInfo.persons[0].friedsList;
console.log(friend1, friend2);
// Expected Output: Nabil Habib
xxxxxxxxxx
const person = {
firstName: 'Adil',
lastName: 'Arif',
age: 25,
job: 'web-developer',
love: 'coding',
friedsList: {
friend1: 'Abir',
friend2: 'Adnan'
}
}
const { friend1, friend2 } = person.friedsList;
console.log(friend1, friend2);
//Expected output: Abir Adnan
xxxxxxxxxx
// destructuring array & nested array & combine array into single array
let person = ["John", "Sandy", "Sam", ["Mike", "Max"], "Diego", "Paul"];
// empty comma is like skipping array index. I skipped "Sam"
const [a, b, , c, d] = person;
let friend = [d, "Tom", "Jerry"]
let newFriend = [d, "Tom", "Jerry"]
console.log(a); // output: "John"
console.log(b); // output: "Sandy"
console.log(c); // output: [ "Mike", "Max" ]
console.log(d); // output: ["Diego", "Paul"]
console.log(friend); // output: [ [ 'Diego', 'Paul' ], 'Tom', 'Jerry' ]
console.log(newFriend); // output: [ 'Diego', 'Paul', 'Tom', 'Jerry' ]
xxxxxxxxxx
const myFunc = ({event: {target: {name,secondName}}}) => {
console.log(name);
console.log(secondName);
}
myFunc({event: {target: {name: 'fred'}}})
xxxxxxxxxx
const person = {
id: 0133,
name: "Robert",
positon: "web-developer",
salary: 8000,
pColor: "red",
pSports: "football",
pMovies: ["word war 1", "destroy the world", "long way", "Where is my home"],
pChild: {
firstChild: "Adiba",
secondChild: "Alvi"
}
}
const { secondChild } = person.pChild;
console.log(secondChild);
//Output: Alvi
xxxxxxxxxx
// nested array elements
const arrValue = ['one', ['two', 'three']];
// nested destructuring assignment in arrays
const [x, [y, z]] = arrValue;
console.log(x); // one
console.log(y); // two
console.log(z); // three