ES6基础语法之变量的结构赋值

本文详细介绍了ES6中的解构赋值语法,包括数组、对象、字符串、数值和布尔值以及函数参数的解构赋值。解构赋值允许我们方便地从数组或对象中提取值,分配给不同的变量。对于数组,它基于位置匹配赋值,支持默认值;对象解构则依赖于属性名称,可以设置默认值,并支持嵌套结构。字符串的解构实际上是将其转换为类似数组的对象。数值和布尔值在解构时会被转化为对象。最后,函数参数的解构赋值使我们可以直接对参数进行模式匹配,简化代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、解构赋值

解构赋值语法是一个 Javascript 表达式,这使得可以将值从数组属性从对象提取到不同的变量中。

二、数组的解构赋值

1、基本介绍

let [a, b, c] = [1, 2, 3] 等价于 let a = 1;let b = 2;let c = 3;
这种写法属于“模式匹配”,只要等号两边的模式相同,左边的变量就会被赋予对应的值。如果解构不成功,变量的值就等于undefined。

示例:

    let [foo, [[bar], baz]] = [1, [[2], 3]];
    let [ , , third] = ["foo", "bar", "baz"];
    let [x, , y] = [1, 2, 3];
    let [head, ...tail] = [1, 2, 3, 4];
    let [a, b, ...z] = ['a'];

2、默认值

let [foo = true] = [];     //foo : true
let [x, y = 'b'] = ['a']         //x='a', y='b'

注意!!! ES6 内部使用严格相等运算符(===),判断一个位置是否有值。所以,只有当一个数组成员严格等于undefined,默认值才会生效.
如下:

    let [x = 1] = [undefined];     //x: 1
    let [x = 1] = [null];       //x: null

3、代码示例:

<script>
    let [foo, [bar, baz]] = [1, [[2], 3]];
    console.log(foo,bar,baz)//1 [2] 3
    let [head, ...tail] = [1, 2, 3, 4];
    console.log(head,tail)//1 [2 3 4]

    let [a="a"]=[null];
    console.log(a)//null
</script>

三、 对象的解构赋值

解构不仅可以用于数组,还可以用于对象

let { foo, bar } = { foo: "aaa", bar: "bbb" };

对象的解构与数组有一个重要的不同。数组的元素是按次序排列的,变量的取值由它的位置决定;而对象的属性没有次序,变量必须与属性同名,才能取到正确的值。
如果变量名与属性名不一致,必须写成下面这样:

1.  let { foo: baz } = { foo: 'aaa', bar: 'bbb' };
2.  let obj = { first: 'hello', last: 'world' };
    let { first: f, last: l } = obj;
    f // 'hello'        l // 'world'

1、对象的解构赋值的内部机制
本质上,对象的解构赋值是下面形式的简写

    let { foo: foo, bar: bar } = { foo: "aaa", bar: "bbb" };

也就是说,对象的解构赋值的内部机制,是先找到同名属性,然后再赋给对应的变量。真正被赋值的是后者,而不是前者。
2、嵌套
与数组一样,解构也可以用于嵌套结构的对象

let obj = {
        p: [
         'Hello',
         { y: 'World' }
         ]
};

let { p: [x, { y }] } = obj;  // x:"Hello" y:"World"

示例如下:

const node = {
  loc: {
    start: {
      line: 1,
      column: 5
    }
  }
};

let { loc, loc: { start }, loc: { start: { line }} } = node;
// line :1 ; 
//loc :Object {start: Object} 
//start : Object {line: 1, column: 5}


let obj = {};
let arr = [];
({ foo: obj.prop, bar: arr[0] } = { foo: 123, bar: true });
// obj :{prop:123}
// arr: [true]

3、陷阱

let x; {x} = {x: 1};

上面代码的写法会报错,因为 JavaScript 引擎会将{x}理解成一个代码块,从而发生语法错误。只有不将大括号写在行首,避免 JavaScript 将其解释为代码块,才能解决这个问题。

// 正确的写法
let x; ({x} = {x: 1});

4、原型:

<script>
   let {map,forEach} = [];
   console.log(map,forEach)//map:ƒ map() { [native code] } ;forEach: ƒ forEach() { [native code] }
</script>

四、字符串的解构赋值

字符串也可以解构赋值。这是因为此时,字符串被转换成了一个类似数组的对象。

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

五、数值和布尔值的解构赋值

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

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

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

解构赋值的规则是,只要等号右边的值不是对象或数组,就先将其转为对象。由于undefined和null无法转为对象,所以对它们进行解构赋值,都会报错。

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

六、 函数参数的解构赋值

函数的参数也可以使用解构赋值。

function add([x, y]){
  return x + y;
}
add([1, 2]); // 3
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值