Geekerstar

前端开发之ECMAScript6学习笔记(五)解构
解构,一种黑魔法,让数据访问更便捷。解构是从对象中提取出更小元素的过程。赋值是对解构出来的元素进行重新赋值。解构的...
扫描右侧二维码阅读全文
26
2018/02

前端开发之ECMAScript6学习笔记(五)解构

解构,一种黑魔法,让数据访问更便捷。解构是从对象中提取出更小元素的过程。赋值是对解构出来的元素进行重新赋值。

JavaScript解构

解构的分类

1、对象解构

2、数组解构

3、混合解构

4、解构参数

对象解构

对象解构简单的例子

    let obj = {
      a: 1,
      b: [1, 2]
    }
    // 对象解构
    const { a, b } = obj
    console.log(a, b) //1  [1, 2]

在函数中使用解构赋值

解构是将对象或者数组的元素一个个提取出来,而赋值是给元素赋值,解构赋值的作用就是给对象或者数组的元素赋值。

在调用test()函数的时候,我们给参数设置了默认值3,如果不重新赋值,则打印出3,3,但是进行解构赋值后,将props对象的参数解构赋值给a和b,所以打印结果是{a: 1, b: 2}

    let props = {
      a: 1,
      b: 2
    }
    function test(value) {
      console.log(value)
    }
    test({a=3, b=3} = props) // {a: 1, b: 2}

下面这个例子定义了a = 3,b = 3两个变量,现在我们想修改这2个变量的值,采用解构赋值的方式可以这样做:定义一个props对象,该对象包含2个属性a和b,然后进行解构赋值,这时就能更新变量a和b的value。

    let props = {
      a: 1,
      b: 2
    },
    a = 3,
    b = 3;
    //解构赋值
    ({ a, b } = props)
    console.log(a, b) // 1, 2

嵌套对象解构

当对象层次较深时,你也可以解构出来。

    let obj = {
      a: {
        b: {
          c: 5
        }
      }
    }
    const {a: {b}} = obj
    console.log(b.c) // 5

数组解构

数组解构比对象解构简单,因为数组只有数组字面量,不需要像对象一个使用key属性。

数组解构

你可以选择性的解构元素,不需要解构的元素就使用逗号代替。

    let arr = [1, 2, 3]
    
    //解构前2个元素
    const [a, b] = arr
    console.log(a,b) //1 2
    
    //解构中间的元素
    const [, b,] = arr
    console.log(b) // 2

解构赋值

如果你没有看明白上面说到的对象解构赋值的含义,那么看完下面的数组解构赋值,或许你会有比较清晰的理解。

这个例子中,正常情况下打印a的值是haha,但是将数组arr的第一个元素解构赋值给a,a的值就变成了1。

    //初始化一个变量a
    let a = "haha";
    //定义一个数组
    let arr = [1, 2, 3];
    //解构赋值a,将arr数组的第一个元素解构赋值给a,
    [a] = arr;
    console.log(a); // 1

使用解构赋值,还可以调换2个变量的值。

    let a = 1, b = 2;
    [a, b] = [b, a];
    console.log(a, b); // 2 1 

嵌套数组解构

    let arr = [1, [2, 3], 4];
    let [a, [,b]] = arr;
    console.log(a, b) // 1 3
    
    //实际解构过程,左边的变量和右边的数组元素一一对应下标。
    var a = arr[0],
    _arr$ = arr[1],
    b = _arr$[1];

不定元素解构

三个点的解构赋值必须放在所有解构元素的最末尾,否则报错。

    let arr = [1, 2, 3, 4];
    let [...a] = arr;
    console.log(a) //[1,2,3,4] 这种做法就是克隆arr数组。

混合解构

混合解构指的是对象和数组混合起来,执行解构操作,没什么难度。

    let obj = {
      a: {
        id: 1
      },
      b: [2, 3]
    }
    
    const {
      a: {id},
      b:[...arr]
    } = obj;
    console.log(id, arr) //id = 1, arr = [2, 3]

解构参数

当给函数传递参数时,我们可以对每个参数进行解构,我给option的参数设置了默认值,这样可以防止没有给option传参导致的报错情况。

    function Ajax(url, options) {
      const {timeout = 0, jsonp = true} = options
      console.log(url, timeout, jsonp)
    };
    Ajax('baidu.com', {
      timeout: 1000,
      jsonp: false
    }) // "baidu.com" 1000 false

总结

本章讲解了对象解构赋值和数组解构赋值,以及对象和数组混合情况下的解构赋值操作,最后一个知识点是解构函数的参数。每一个都是重点,特别是最后一个,解构参数恐怕你经常在用了,只是通常你没发现。


上一章:前端开发之ECMAScript6学习笔记(四)扩展对象之功能性
下一章:前端开发之ECMAScript6学习笔记(六)Symbol


返回目录

最后修改:2018 年 02 月 27 日 09 : 52 PM
如果觉得我的文章对你有用,请随意赞赏

发表评论