ES6语法--解构赋值

2017-09-19  本文已影响0人  bjhu电net

什么是解构赋值?

左边一种结构,右面一种结构,左右分别赋值。

分类:

数组解构赋值,对象结构赋值,字符串解构赋值,布尔值结构赋值,函数参数解构赋值,数值解构赋值。

数值结构赋值:


{

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)
}

{}是声明一个块级作用域,防止变量的重复声明。

上一篇 下一篇

猜你喜欢

热点阅读