JavaScript解构赋值(代码说明ES6数组, 对象, 函数的解构赋值)

解构赋值

es6为我们对变量赋值提供了新的方式.


**方式1 : **

        //ES5
        var a = 1;
        var b = 2;
        var c = 3;
        //这是在es6之前的赋值方式
        
        //ES6
        var [a,b,c] = [1,2,3];
        console.log(a,b,c);
        //变量会分别辅助到a,b,c中去, 因此输出结果为1,2,3;
        
        const arr = ['a', 'b', 'c'];
        const [name1, name2, name3] = arr;
        //当然对于const, 和let的解构赋值也是可以的;
        console.log(name1);
        console.log(name2);
        console.log(name3);

方式2 : **
本质是上述匹配属于一种
模式匹配**, 也就是只要等号两边的模式相同,左边的变量就会被赋予对应的值。

        let [foo,[[bar],baz]] = [1,[[2],3]]; 
        console.log(foo,bar,baz);
        //输出, 1 2 3
        
        let [x,,y] = [1,2,3];
        let [head,...tail] = [1,2,3,4,5];
         // ...tail 把后续元素当成数组 如果 没有后续元素那么就是空数组。
        let [a,b,...z] = ['a'];
        
        console.log(x,y);
        //输出, 1 3
        console.log(head,tail);
        //输出, 1 Array(4)
        console.log(a,b,z);
        //输出, a undefined Array(0)

如下情况会报错 右边不是数组(或者严格地说,不是可遍历的结构)

        let [foo] = 1;
        let [foo] = false;
        let [foo] = NaN;
        let [foo] = undefined;
        let [foo] = null;
        let [foo] = {};

**方式3: **

默认赋值
只有右侧的值严格等于undefined的时候才生效。

       var [foo = true] = [];
       console.log(foo);//true
       var [x1, y1 = 'b'] = ['a'];
       console.log(x1,y1);//a, b
       var [x2, y2 = 'b'] = ['a',undefined];
       console.log(x2,y2);//a, b
       
       //null 不等于undefined 所以不生效
       var [x3 = 1] = [null];
       console.log(x3);//null

**方式4: **

惰性求值 只有在用到的时候,才会求值

       function f () {
        return 'aaa';
       }
       let [x1 = f()] = [1];
       let [x2 = f()] = [];
       console.log(x1);//1
       console.log(x2);//aaa

默认赋值规则

默认赋值可以应用解构赋值的其他变量
首先看右侧有无和左侧对应的值,没有的话看左侧从左到右解析

        let [x1 = 1, y1 = x1] = [];
        let [x2 = 1, y2 = x2] = [2];
        let [x3 = 1, y3 = x3] = [1,2];             
             
        console.log(x1,y1);//1 1
        console.log(x2,y2);//2 2
        console.log(x3,y3);//1 2

        let [x4 = y4, y4 = 1] = [];   --var 和 let 有区别 
        console.log(x4,y4);//报错, let不具有变量声明提前
        var [x4 = y4, y4 = 1] = [];   --var 和 let 有区别 
        console.log(x4,y4);//undefined 1

**方式5: **

对象的解构赋值

对象的解构赋值是按照属性名称决定的

        var {foo,bar} = {foo: 'aaa', bar: 'bbb'};
        console.log(foo);//输出aaa
        console.log(bar);//输出bbb
        var {baz} = {foo: 'aaa', bar: 'bbb'};
        console.log(baz);//输出undefined

**对象赋值注意: **一个已经声明的变量用于解构赋值 必须非常小心

       var x;
        // js引擎会将{x} 理解成一个代码块,从而发生语法错误。只有不将大括号写在行首可以避免这个问题
        //{x} = {x:1};     
        ({x} = {x:1});
        console.log(x);

同时对象的结构赋值, 也可以用于嵌套结构

        var obj = {
            p: [
                'hello',
                {y: 'world'}
            ]
        };
        var {p: [x, { y }] } = obj;

        console.log(x,y);//hello word

对象结构也可以自定默认值 默认生效条件和数组一样都是undefined

        var {z = 3} = {};
        console.log(z);//3  
        var {x, y = x} = {x:1};  
        console.log(x,y);//1 1

**方式6: **

字符串的解构赋值 字符串会转化成一个类数组的对象

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

类数组对象有length属性 所以len是5

        let {length : len} = 'hello';
        console.log(len);//5

**方式7: **
函数参数的解构赋值
函数add的参数表面上是一个数组,但在传入参数的那一刻,数组参数就被结构成变量 x 和 y

        function add([x,y]) {
            return x + y;
        }
        console.log(add([1, 2]));//3

练习

巩固一下上面的知识

        function move({x = 0,y = 0} = {}) {
            console.log([x,y]);
        }
        move({x:3,y:8});//3, 8
        move({x:3});//3, 0
        move({});//0, 0
        move();//0, 0



        function deal({x,y} = {x: 0 , y: 0}) {
            console.log([x,y]);
        }
        deal({x: 3,y: 8});//3, 8
        deal({x: 3});//3, undefined
        deal({});//undefined undefined
        deal();//undefined undefined

解构赋值用途

下面简单举例说明一下解构赋值的用途
1.交换变量

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

2.从函数返回多个值

        function example () {
            return [1,2,3];
        }        
        var [a, b, c] = example();//1 2 3

3.函数参数的定义

        function f2({x,y,z}) {
            console.log(x,y,z);//2 1 3
        }        
        f2({z:3,x:2,y:1});

4.提交json数据

      var jsonData= {
            id: 42,
            status: 'ok',
            data:[888,999]            
        }
        let {id,status,data:number} = jsonData;
        console.log(id, status,number);//42 ok [888, 999]
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容

  • 函数参数的默认值 基本用法 在ES6之前,不能直接为函数的参数指定默认值,只能采用变通的方法。 上面代码检查函数l...
    呼呼哥阅读 3,347评论 0 1
  • 基本用法 ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring...
    嘉奇呦_nice阅读 789评论 0 2
  • 1.数组的解构赋值 2.对象的解构赋值 3.字符串的解构赋值 4.数值和布尔值的解构赋值 5.函数参数的解构赋值 ...
    卞卞村长L阅读 916评论 0 0
  • 大概有一年半的时间没有再提笔写过字,却依然时常去关注一些书法类的展览以及一切活动,还是会觉得美好 会觉得自己写字...
    安安睡不醒阅读 96评论 0 0
  • 不知道有多少人今天早上起来,遭遇了晴天霹雳... ... 我不是Linkin Park的忠实粉丝,对于主唱Ches...
    MonagneM阅读 920评论 0 1