Let's talk about destructuring in JS ES6

Let's talk about destructuring in JS ES6

Overview

es6 adds a new way to get specified elements from an array or object, which is what we are going to talk about today: destructuring.

Let's talk about array deconstruction first

Before destructuring, we usually get the specified element in the array based on the index:

const arr = [1, 2, 3]; 
const a = arr[1];

After deconstruction, we can use the following method to quickly get an element in the array:

const arr = [1, 2, 3];
const [a, b, c] = arr;

console.log(a);
console.log(b);
console.log(c);

This prints out the values ​​of a, b, and c respectively:

1

2

3

If we only want to get the first two elements, we can write:

const arr = [1, 2, 3];
const [a, b] = arr;

console.log(a);
console.log(b);

We can also combine the spread operator to get multiple elements specified in the array, for example:

const arr = [1, 2, 3];
const [a, ...brr] = arr;

console.log(a);
console.log(brr);

In this way, brr is an array consisting of elements other than 1, and the printed values ​​of a and brr are:

1

[twenty three]

What if we only want to get a certain element in the array? For example, if I only want to get 2 in the array, how should I write it?

const arr = [1, 2, 3];
const [, a] = arr;
console.log(a);

Above, we use a comma as a placeholder to ensure that our deconstruction is consistent with the position of the array itself to obtain an element at a specific position.
As you can see, the emergence of destructuring makes it easier for us to get one or more elements at a specified position in the array. This is also an important application of it in the code.

After talking about array deconstruction, let's talk about

Deconstruction of objects

Unlike array destructuring, object destructuring is matched based on property names. Since objects do not have an order like array subscripts, they cannot be extracted using subscripts.
For example, if we define an object obj, and we want to get the value of its name attribute, we can write it like this:

const obj = {
    name: 'wudixiaodoujie',
    age: 18
};
const { name } = obj;
console.log(name);
wudixiaodoujie

const age = 0;
const { age: perAge } = obj;
console.log(perAge);
18

Object deconstruction is widely used. For example, if we need to frequently call a property or method of an object, we can assign it to a variable through deconstruction. Calling it through a variable can reduce the amount of code to a certain extent.

The above is the detailed content of deconstruction in JS ES6. For more information about deconstruction in JS ES6, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • JS quickly master ES6 class usage
  • Detailed explanation of JS ES6 variable destructuring assignment
  • Several magical uses of JS ES6 spread operator
  • JS ES6 asynchronous solution
  • Implementation of Javascript Destructuring in ES6
  • Usage and difference between let and const in ES6 specification in JavaScript
  • 24 ES6 methods to solve practical JS development problems (summary)
  • Detailed explanation of the implementation principle of JavaScript ES6 Class
  • Specific use of ES6 Proxy in JavaScript
  • Detailed explanation of JS ES6 coding standards

<<:  Common commands for deploying influxdb and mongo using docker

>>:  Detailed explanation of 7 SSH command usages in Linux that you don’t know

Recommend

The homepage design best reflects the level of the web designer

In the many projects I have worked on, there is b...

Introduction to the process of building your own FTP and SFTP servers

FTP and SFTP are widely used as file transfer pro...

Implementing custom scroll bar with native js

This article example shares the specific code of ...

Summary of special processing statements of MySQL SQL statements (must read)

1. Update the entire table. If the value of a col...

In-depth explanation of the principle of MySQL Innodb index

introduction Looking back four years ago, when I ...

Three ways to implement virtual hosts under Linux7

1. Same IP address, different port numbers Virtua...

Detailed explanation of mysql5.6 master-slave setup and asynchronous issues

Table of contents 1. MySQL master-slave replicati...

A performance bug about MySQL partition tables

Table of contents 2. Stack analysis using pt-pmap...

Hyperlink icon specifications: improve article readability

1. What is the hyperlink icon specification ?<...

Vue implements a small countdown function

Countdown function needs to be implemented in man...

Win10 installation Linux system tutorial diagram

To install a virtual machine on a Windows system,...

JavaScript exquisite snake implementation process

Table of contents 1. Create HTML structure 2. Cre...

MYSQL database GTID realizes master-slave replication (super convenient)

1. Add Maria source vi /etc/yum.repos.d/MariaDB.r...