什么是解构赋值?
左边一种结构,右面一种结构,左右分别赋值。
分类:
数组解构赋值,对象结构赋值,字符串解构赋值,布尔值结构赋值,函数参数解构赋值,数值解构赋值。
数值结构赋值:
{
leta,b,rest;
[a,b]=[1,2];
console.log(a,b)
}
{
leta,b,rest;
[a,b,...rest]=[1,2,3,4,5,6]
console.log(a,b,rest)
}
{
leta,b,rest;
[a,b,c=3]=[1,2]
console.log(a,b,c)
}
//rest会输出一个数组[3,4,5,6]
//如果解构赋值没有一一对应,那么少的那个就是undefined。c=3是赋值一个默认值,如果右侧有值,会将默认值覆盖掉。
数组解构赋值可以适用于变量交换。当对象返回一个数组的时候,可以有选择性的提取数组的值。在不知道函数返回数组的长度不确定是,可以采用...的形式将变量赋值给一个数组。
{
function f(){
return [1,2];
}
let a,b;
[a,b]=f();
console.log(a,b)
}
{
function f(){
return [1,2,3,4,5];
}
let a,b;
[a,,,b]=f();
console.log(a,b)
}
//a是1,b是4
对象结构赋值:
{
let a,b;
({a,b}={a:1,b:2});
console.log(a,b)
}
{
let o={p:42,q:true};
let {p,q}=o;
console.log(p,q)
}
{
let {a=10,b=5}={a:3};
console.log(a,b)
}
嵌套对象的解构赋值
{
let metaData={
title:'abc',
test:[{
title:'test',
desc:"description"
}]
}
let {title:esTitle,test:[{title:cnTitle}]}=metaData;
console.log(esTitle,cnTitle)
}
{}是声明一个块级作用域,防止变量的重复声明。
网友评论