ES6 Destructuring Assignment
ES6 provides a new feature called destructing assignment that allows you to destructure properties of an object or elements of an array into individual variables.
Let’s start with the array destructuring.
Introduction to JavaScript Array destructuring
Assuming that you have a function that returns an array of numbers as follows:
function getScores() {
return [70, 80, 90];
}
Code language: JavaScript (javascript)
The following invokes the getScores()
function and assigns the returned value to a variable:
let scores = getScores();
Code language: JavaScript (javascript)
To get the individual score, you need to do like this:
let x = scores[0],
y = scores[1],
z = scores[2];
Code language: JavaScript (javascript)
Prior to ES6, there was no direct way to assign the elements of the returned array to multiple variables such as x
, y
and z
.
Fortunately, starting from ES6, you can use the destructing assignment as follows:
let [x, y, z] = getScores();console.log(x); // 70
console.log(y); // 80
console.log(z); // 90
Code language: JavaScript (javascript)
The variables x
, y
and z
will take the values of the first, second, and third elements of the returned array.
Note that the square brackets []
look like the array syntax but they are not.
If the getScores()
function returns an array of two elements, the third variable will be undefined
, like this:
function getScores() {
return [70, 80];
}let [x, y, z] = getScores();
console.log(x); // 70
console.log(y); // 80
console.log(z); // undefined
Code language: JavaScript (javascript)
In case the getScores()
function returns an array that has more than three elements, the remaining elements are discarded. For example:
function getScores() {
return [70, 80, 90, 100];
}let [x, y, z] = getScores();
console.log(x); // 70
console.log(y); // 80
console.log(z); // 90
Code language: JavaScript (javascript)
Array Destructuring Assignment and Rest syntax
It’s possible to take all remaining elements of an array and put them in a new array by using the rest syntax (...)
:
let [x, y ,...args] = getScores();
console.log(x); // 70
console.log(y); // 80
console.log(args); // [90, 100]
Code language: JavaScript (javascript)
The variables x
and y
receive values of the first two elements of the returned array. And the args
variable receives all the remaining arguments, which are the last two elements of the returned array.
Note that it’s possible to destructure an array in the assignment that separates from the variable’s declaration. For example:
let a, b;
[a, b] = [10, 20];
console.log(a); // 10
console.log(b); // 20
Code language: JavaScript (javascript)
Setting default values
See the following example:
function getItems() {
return [10, 20];
}let items = getItems();
let thirdItem = items[2] != undefined ? items[2] : 0;
console.log(thirdItem); // 0
Code language: JavaScript (javascript)
How it works:
- First, declare the
getItems()
function that returns an array of two numbers. - Then, assign the items variable to the returned array of the getItems() function.
- Finally, check if the third element exists in the array. If not, assign the value 0 to the
thirdItem
variable.
It’ll be simpler with the destructuring assignment with a default value:
let [, , thirdItem = 0] = getItems();console.log(thirdItem); // 0
Code language: JavaScript (javascript)
If the value taken from the array is undefined
, you can assign the variable a default value, like this:
let a, b;
[a = 1, b = 2] = [10];
console.log(a); // 10
console.log(b); // 2
Code language: JavaScript (javascript)
If the getItems()
function doesn’t return an array and you expect an array, the destructing assignment will result in an error. For example:
function getItems() {
return null;
}let [x = 1, y = 2] = getItems();
Code language: JavaScript (javascript)
Error:
Uncaught TypeError: getItems is not a function or its return value is not iterable
Code language: JavaScript (javascript)
A typical way to solve this is to fallback the returned value of the getItems()
function to an empty array like this:
function getItems() {
return null;
}let [a = 10, b = 20] = getItems() || [];
console.log(a); // 10
console.log(b); // 20
Code language: JavaScript (javascript)
Nested array destructuring
The following function returns an array that contains an element which is another array, or nested array:
function getProfile() {
return [
'John',
'Doe',
['Red', 'Green', 'Blue']
];
}
Code language: JavaScript (javascript)
Since the third element of the returned array is another array, you need to use the nested array destructuring syntax to destructure it, like this:
let [
firstName,
lastName,
[
color1,
color2,
color3
]
] = getProfile();console.log(color1, color2, color3); // Red Green Blue
Code language: JavaScript (javascript)
Array Destructuring Assignment Applications
Let’s see some practical examples of using the array destructuring assignment syntax.
1) Swapping variables
The array destructuring makes it easy to swap values of variables without using a temporary variable:
let a = 10,
b = 20;[a, b] = [b, a];
console.log(a); // 20
console.log(b); // 10
Code language: JavaScript (javascript)
2) Functions that return multiple values
In JavaScript, a function can return a value. However, you can return an array that contains multiple values, for example:
function stat(a, b) {
return [
a + b,
(a + b) / 2,
a - b
]
}
Code language: JavaScript (javascript)
And then you use the array destructuring assignment syntax to destructure the elements of the return array into variables:
let [sum, average, difference] = stat(20, 10);
console.log(sum, average, difference); // 30, 15, 10
Code language: JavaScript (javascript)
In this tutorial, you have learned how to use the ES6 destructuring assignment to destructure elements in an array into individual variables.