ECMAScript(解构)

解构

数组解构

  • 基本用法
    let [a , b] = [1, 2] // a = 1 b = 2
    let [a, b] = 1 // 报错
    let [a, b] = [1] // a = 1 b = undefined
    let [a, b] = [1, null] // a = 1 b = null
    let [a, ...b] = [1, 2, 3, 4] // a = 1 b = [2, 3, 4]
    let [x, y, z] = new Set(['a', 'b', 'c']) // x = a  y = b  z = c
    
  • 默认值
    let [x = 1, y = x] = [2];    // x=2; y=2
    

对象解构

  • 基本用法
    let { bar, foo } = { foo: 'aaa', bar: 'bbb' }; // bar = bbb foo = aaa
    let { bar, foo } = { bar: 'bbb' }; // bar = bbb foo = undefined
    // let {bar, foo} 是 let {bar: bar, foo: foo} 的简写 真正赋给值的是:后的
    // 例如
    let { bar: foo } = { bar: 'bbb', foo: 'aaa'} // foo = bbb
    
    // 下面代码中,foo是匹配的模式,baz才是变量。真正被赋值的是变量baz,而不是模式foo
    let { foo: baz } = { foo: 'aaa', bar: 'bbb' };
    baz // "aaa"
    foo // error: foo is not defined
    
  • 用于嵌套结构的对象
    let obj = {
      p: [
        'Hello',
        { y: 'World' }
      ]
    };
    
    let { p: [x, { y }] } = obj;
    x // "Hello"
    y // "World"
    
    这时p是模式,不是变量,因此不会被赋值。如果p也要作为变量赋值,可以写成下面这样
    let obj = {
      p: [
        'Hello',
        { y: 'World' }
      ]
    };
    
    let { p, p: [x, { y }] } = obj;
    x // "Hello"
    y // "World"
    p // ["Hello", {y: "World"}]
    
    如果解构模式是嵌套的对象,而且子对象所在的父属性不存在,那么将会报错。
    // 报错
    let {foo: {bar}} = {baz: 'baz'};
    
  • 对象的解构赋值可以取到继承的属性
      const obj1 = {};
      const obj2 = { foo: 'bar' };
      Object.setPrototypeOf(obj1, obj2);
    
      const { foo } = obj1;
      foo // "bar"
    
    上面代码中,对象obj1的原型对象是obj2。foo属性不是obj1自身的属性,而是继承自obj2的属性,解构赋值可以取到这个属性。
  • 默认值
 let {x, y = 5} = {x: 1};
 x // 1
 y // 5

 let {x: y = 3} = {};
 y // 3

 let {x: y = 3} = {x: 5};
 y // 5

默认值生效的条件是,对象的属性值严格等于undefined。

let {x = 3} = {x: undefined};
x // 3

let {x = 3} = {x: null};
x // null
  • 注意点
    如果要将一个已经声明的变量用于解构赋值

    // 错误的写法
    let x;
    {x} = {x: 1};
    // SyntaxError: syntax error\
    // 因为 JavaScript 引擎会将{x}理解成一个代码块,等号左边是不允许出现代码块语句的,从而发生语法错误
    
    // 正确的写法
    let x;
    ({x} = {x: 1});
    

    由于数组本质是特殊的对象,因此可以对数组进行对象属性的解构

    let arr = [1, 2, 3];
    let {0 : first, [arr.length - 1] : last} = arr;
    first // 1
    last // 3
    

字符串的解构

const [a, b, c, d, e] = 'hello';
a // "h"
b // "e"
c // "l"
d // "l"
e // "o"


let {length : len} = 'hello';
len // 5

数值和布尔值的解构赋值

解构赋值时,如果等号右边是数值和布尔值,则会先转为对象。

let {toString: s} = 123;
s === Number.prototype.toString // true

let {toString: s} = true;
s === Boolean.prototype.toString // true



let { prop: x } = undefined; // TypeError
let { prop: y } = null; // TypeError

数值和布尔值的包装对象都有toString属性,因此变量s都能取到值。
解构赋值的规则是,只要等号右边的值不是对象或数组,就先将其转为对象。由于undefined和null无法转为对象,所以对它们进行解构赋值,都会报错。

函数参数赋值解构

[[1, 2], [3, 4]].map(([a, b]) => a + b);

赋值默认值同上

圆括号问题

不可使用圆括号

  • 声明语句(函数参数也是声明)
let ([a]) = [1] 或(let [a] = [1]) // 报错
  • 括号包含了模式
({a: b}) = {a: 1}
{(a): b} = {a: 1}

使用圆括号

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