解构赋值
解析一个数据结构并赋值,可以快速的从对象或数组中取出需要的内容,对象使用大括号,数组使用中括号
解构对象
之前从对象中取到内容的方式
let obj = {
name:"张三",
age:12,
sex:"男",
}
let name = obj.name;
let age = obj.age;
解构的方式:
let obj = {
name:"张三",
age:12,
sex:"男",
}
let {name} = obj;
/*
表示从obj中获取name属性,并赋值给声明的name变量
*/
使用说明:
- obj必须是一个对象
- obj中必须有name属性
还可以一次性解构多个变量:
let obj = {
name:"张三",
age:12,
sex:"男",
}
let {name,age} = obj; // 声明并赋值了两个变量
可以将变量名换成一个别的名字:
let obj = {
name:"张三",
age:12,
sex:"男",
}
let {name:username,age:a} = obj; // 将obj的name属性值赋值给username变量,age属性值赋值给变量a
多级解构:
let obj = {
name:"张三",
age:12,
sex:"男",
wife:{
name:"翠花",
age:11,
}
}
let {wife} = obj;
let {name} = wife;
// 写为一行
let {wife:{name:wname}} = obj;
解构数组
let arr = [1,2,3];
let [num1] = arr; // 从数组中拿出第一个元素赋值给num1变量
使用说明:
解构数组的时候是按顺序取出数组中的值,解构一个变量,只能拿到第一个元素
解构多个元素:
let arr = [1,2,3];
let [num1,num2] = arr; // num1 = arr[0] num2 = arr[1]
多维数组解构:
let arr = [1,2,3,[4,5,6]];
let [a,b,c,[aa,bb]] = arr;
console.log(aa,bb); // 4 5
利用结构交换两个变量的值:
let num1 = 1;
let num2 = 2;
[num2,num1] = [num1,num2]