JavaScript Destructuring Assignment - 2

JavaScript Destructuring Assignment - 2

·

3 min read


image.png


We've covered the basics of destructuring assignment. This article is the continuation of part 1

Destructuring assignment is a more convenient and special syntax that allows unpacking of arrays or objects into separate variables. It is used on array, objects, and functions.

Array destructuring

Let's see a couple of examples below:

const arr = [ "Bello", "Osagie", "Noah" ];
const [ surName, firstName, otherName ] = arr;
// split individual items into separate variables 
// => "Bello Osagie Noah".split(' ');

console.log(surName); // Bello => surName = arr[0]
console.log(firstName);  // Osagie => firstName= arr[1]
console.log(otherName );  // Noah => otherName = arr[2]

The example above is the same as below:

const [ surName, firstName, otherName ] = "Bello Osagie Noah".split(' ');

console.log(surName); // Bello => surName = arr[0]
console.log(firstName);  // Osagie => firstName= arr[1]
console.log(otherName );  // Noah => otherName = arr[2]

Destructuring allows certain elements in an array to be omitted by omitting the element variable.

const arr = [ "Bello", "Osagie", "Noah" ]
const [ surName, /*omitted*/ , otherName ] = arr;

console.log(surName); 
console.log(otherName);

It works with any iterable data structure like strings, objects, sets, etc.

// string
const [ a, b, c ] = "xyz";
console.log(a); // x
console.log(b); // y
console.log(c); // z

//obj
const obj = { one: 1, two: 2, three: 3 };
const { one, two, three } = obj;
console.log(one);  // 1
console.log(two);  // 2
console.log(three); // 3

// set
const [ one_, two_, three_ ] = new Set([1, 2, 3]);
console.log(one_) // 1
console.log(two_) // 2
console.log(three_) // 3

You can also unpack numbers to a variable by the rest parameters.

const [ one, two, ...numb ] = [ 1, 2, 3, 4, 5, 6 ]
// the rest will be all except one and two

console.log(one); // 1
console.log(two); // 2
console.log(numb); // [ 3, 4, 5, 6 ]

The rest operation above works on objects also:

See below:

const obj = {
  one: 1,
  two: 2,
  three: 3,
  four: 4,
  five: 5,
  six: 6,
};

const { one, two, ...numb } = obj;

console.log(one); // 1
console.log(two); // 2
console.log(numb); // { three: 3, four: 4, five: 5, six: 6 }

We can also add properties in an object by setting default values (use =).

const obj = { one: 1 };

const { two = 2, three = 3, one } = obj;

console.log(one);  // 1
console.log(two);  // 2
console.log(three); // 3

We can set default values also in arrays.

const [ firstName = "John", lastName = "Bello" ] = [ "Osagie" ];

console.log(firstName);    // Osagie
console.log(lastName ); // Bello

We can also swap values of two variables using a destructuring assignment.

let firstName = "Osagie";
let lastName = "Bello";

// swap to firstName=Bello, lastName=Osagie
[ firstName, lastName ] = [ lastName, firstName ];

console.log(`${firstName} ${lastName}`);  // Bello Osagie

We can also destructure to loop over keys-and-values of an object.

const person = {
  name: "Bello",
  age: 27
};

for ( let [ key, value ] of Object.entries(person) ) {
  console.log(`${key}:${value}`);
  /* 
  name:Bello
  age:27
  */
}

It works on iterable objects like maps.

const map = new Map();
    .set("name", "Bello");
    .set("age", "27");

// syntax looks more convenient with map
for (let [key, value] of map) {
  console.log(`${key}:${value}`); 
  /* 
  name:Bello
  age:27
  */
}

We can use restructure an array (object) returned by a function.

const arr = () => {
  return [ 4, 6, 2]
};

const [ four, , two ] = arr();
console.log( arr() ); // [ 4, 6, 2 ]

image.png