zoukankan      html  css  js  c++  java
  • ES6 变量的解构赋值

    ES6允许 按照一定的模式,从数组和对象中提取值,对变量进行赋值,这被称为解构。结构赋值在实际开发中可以大量减少我们的代码量,并且让我们的程序结构更清楚。赋值解构已经看了好多遍了,但是每次记不住,今天来写一篇博客来加深印象

    一、数组的解构赋值

       我觉得数组的解构赋值的作用就是能够同时给多个变量进行赋值,不用像以前那样需要些多个赋值表达式,下面是数组的解构赋值的基本用法

    基本使用方法:

    1.模式匹配:只要等号两边的模式相同,左边的变量就会被赋予对应的值
    let [a,b,c]=[1,2,3];
    console.log(a);         //1
    console.log(b);         //2
    console.log(c);         //3
    //嵌套数组进行解构
    let [foo,[[bar],baz]]=[1,[[2],3]];
    console.log(foo);   //1
    console.log(bar);   //2
    console.log(baz)    //3       
    
     let [x,y,...z]=['a'];
     console.log(x); //a
      console.log(y); //undefined
      console.log(z); //[]
    
    2.不完全解构:等号左边的匹配模式只匹配等号右边数组的一部分
    let [x,y]=[1,2,3];
    console.log(x);         //1
    console.log(y);         //2
    
    3.只要某种数据结构具有Iterator接口,都可以采用数组形式的解构赋值

    例如:对于Set结构,也可以使用数组的解构赋值

    let [x,y,z]=new Set(["a","b","c"]);
    console.log(x);             //a
    
    4.解构赋值允许指定默认值:只有当数组成员严格等于undefiend,默认值才会生效
    var [foo=true]=[];
    console.log(foo);           //true
    
    var [x=1]=[undefined];
    console.log(x);             //1
    
    var [y=1]=[null];
    console.log(y);             //null
    

    二、对象的赋值解构

    基本使用方法:

    1、变量名必须与属性名同名
    var {baz,foo,bar}={foo:"aaa",bar:"bbb"};
    //上面是这个的简写形式:var {baz:baz,foo:foo,bar:baz}={foo:"aaa",bar:"bbb"};
    console.log(baz);       //undefined;
    console.log(foo);       //aaa
    console.log(bar);       //bbb
    
    2、变量名与属性名不同名
    var {foo:baz}={foo:"aaa",bar:"bbb"};
    console.log(baz);      //变量是baz,模式是foo```
    
    ###### 3、对于let和const而言,变量不能重新声明,一旦赋值的变量以前生命过就会报错
    

    let foo;
    let {foo}={foo:1};//报错

    ###### 4.对象的默认值生效的条件是对象的属性值严格等于undefined
    

    var {x=3}={x:undefined};
    console.log(x); //3
    var {y=3}={y:null};
    console.log(y) //null

    ###### 5.已经声明过的变量用于赋值解构需要使用圆括号
    

    var x;
    ({x}={x:1});

    #### 三、字符串的解构赋值:字符串也可以进行解构赋值。因为字符串可以被转换成一个类似数组的对象
    

    const [a,b,c,d,e]='hello';
    console.log(a); //h
    console.log(b); //e
    console.log(c); //c
    console.log(d); //d
    console.log(e); //e

    #### 四、变量赋值解构的用途
    
    ######1.交换变量的值:不用像以前那样麻烦,还需要定义一个中间变量来存取变量的值
    

    var x=1,y=2;
    [x,y]=[y,x];
    console.log(x); //2
    console.log(y); //1

    ###### 2.从函数返回多个值
    
    ####### 2-1返回一个数组:es5中只能定义一个变量去存取返回的数组,然后通过这个变量去访问这个返回的数组的值,而现在可以直接访问这个数组的值  
    

    function example(){
    return [1,2,3];
    }
    var [a,b,c]=example();
    console.log(a) //1```
    ####### 2-2返回一个对象:可以直接取得返回对象里的变量值   

    function example(){
        return {
            foo:1,
            bar:2
        }
    };
    var {foo,bar}=example();
    console.log(foo);    //1
    
    3、函数参数的定义

    ####### 3-1参数是有次序的值    

    function f([x,y,z]){
        console.log(x);     
    }
    f([1,2,3])      //1
    

    ####### 3-2参数是一组无次序的值      

    function f({x,y,z}){
        console.log(x);
    }
    
    f({z:3,y:2,x:3})        //3
    
    4、提取json数据
    var jsonData={
        id:42,
        status:"ok",
        data:[854,222]
    }
    let {id,status,data:number}=jsonData;
    console.log(id,status,number);      //42,"ok",[854,222]
    
    5、遍历Map结构
    var map=new Map();
    map.set('first','hello');
    map.set('second','world');
    
    for(let [key,value] of map){
        console.log(key+" is "+value)   
    }
    
    //first is hello
    //second is world
    

    总结:变量的解构赋值在项目中常常能够用到,他能够给我们带来许多的便利,可以提高工作效率。

  • 相关阅读:
    Win10 VS2013 PCL1.8.1和依赖项VTK8.0.1, QHuall(2.15.2), FLANN1.9.1,Boost1.59.0,Zbil1.2.11和libPNG1.6.34编译安装
    Boost log中的几个问题
    Linux 使用静态库注意事项
    Windows中lib和DLL区别和使用
    CMake: ELF文件加载动态库的位置
    CMake 默认编译、链接选项
    ld 链接选项-L,-rpath-link,-rpath
    动态库的链接和链接选项-L,-rpath-link,-rpath
    Linux共享对象之编译参数 -fPIC
    ny509 因子和阶乘
  • 原文地址:https://www.cnblogs.com/15fj/p/8371243.html
Copyright © 2011-2022 走看看