js解构赋值语法

123 阅读2分钟

js解构赋值语法,是一种让我们从数据或对象中快速提取并赋值给变量的语法。

什么是解构赋值?

解构赋值允许我们通过一种更简洁的方式获取数组或对象中的元素或属性。并把他们赋值给变量。让我们不用通过索引或属性名一个个赋值。而是通过一种简单的模式匹配来赋值。

1.解构数组

让我们从最简单的数组结构开始。假设我们有一个数组:

const colors = ["red", "green", "blue"];

可以通过解构赋值将数组中的值赋值给变量:

const [firstColor, secondColor, thirdColor] = colors; 
console.log(firstColor); // 输出: "red" 
console.log(secondColor); // 输出: "green" 
console.log(thirdColor); // 输出: "blue"

这样我们就可以直接将数组中的变量赋值给对应的变量,而不需要通过索引来获取数组中的元素。

2.解构对象

接下来,让我们看看如何使用解构语法来处理对象。考虑一个简单的对象:

const person = { name: "Alice", age: 25, city: "New York" };

使用解构赋值从对象中提取变量并赋值:

const { name, age, city } = person; 
console.log(name); // 输出: "Alice" 
console.log(age); // 输出: 25 
console.log(city); // 输出: "New York"

默认值和重命名

现在让我们介绍一些更高级的用法。首先是默认值和重命名。

1.默认值

在结构语法中,你可以为变量设置默认值,以防提取到undefined。例如:

const fruits = ["apple", "banana"]; 
const [firstFruit, secondFruit, thirdFruit = "orange"] = fruits; console.log(thirdFruit); // 输出: "orange"

2.重命名

你也可以再解构赋值时重新命名提取的变量:

const { name: personName, age: personAge } = person; console.log(personName); // 输出: "Alice" 
console.log(personAge); // 输出: 25

深入理解嵌套解构

当涉及到嵌套接口(数组或对象中嵌套着数组对象)时,解构语法仍然适用。例如:对于嵌套数组:

const nestedArray = [1, [2, 3], 4]; 
const [first, [second, third], fourth] = nestedArray; 
console.log(second); // 输出: 2 
console.log(third); // 输出: 3

对于嵌套对象

const employee = { name: "Alice", age: 25, job: { title: "Developer", department: "Engineering" } }; 
const { job: { title, department } } = employee; 
console.log(title); // 输出: "Developer" 
console.log(department); // 输出: "Engineering"

应用场景

解构语法在日常开发中有很多应用场景,比如函数返回多个值,或者vue数据传递相关场景。