美文网首页
ES6语法--解构赋值

ES6语法--解构赋值

作者: bjhu电net | 来源:发表于2017-09-19 11:05 被阅读0次

    什么是解构赋值?

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

    分类:

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

    数值结构赋值:

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

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

    相关文章

      网友评论

          本文标题:ES6语法--解构赋值

          本文链接:https://www.haomeiwen.com/subject/tfrwsxtx.html