美文网首页ECMAScript 6
ECMAScript 6 变量的解构赋值

ECMAScript 6 变量的解构赋值

作者: Rising_life | 来源:发表于2019-07-23 11:27 被阅读0次

ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。

数组的解构赋值

以前,为变量赋值,只能直接指定值。

ES6 允许写成下面这样。

上面代码表示,可以从数组中提取值,按照对应位置,对变量赋值。

本质上,这种写法属于“模式匹配”,只要等号两边的模式相同,左边的变量就会被赋予对应的值。

如果解构不成功,变量的值就等于undefined。

解构的默认值:

解构赋值是允许使用默认值的

注意undefined和null的区别。

undefined 相当于什么都没有,foo取默认值。

null相当于有值,但值为null。所以foo并没有取默认值,而是解构成了null。

对象的解构赋值

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

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

变量没有对应的同名属性,导致取不到值,最后等于undefined。

如果变量名与属性名不一致,必须写成下面这样。

圆括号的使用

如果在解构之前就定义了变量,这时候你再解构会出现问题

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

将整个解构赋值语句,放在一个圆括号里面,就可以正确执行。

字符串解构

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

类似数组的对象都有一个length属性,因此还可以对这个属性解构赋值。

函数参数的解构赋值

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

上面代码中,函数add的参数表面上是一个数组,但在传入参数的那一刻,数组参数就被解构成变量x和y。对于函数内部的代码来说,它们能感受到的参数就是x和y。

相关文章

  • ECMAScript 6 变量解构赋值

    为什么解构很有用 ECMAScript 5以及以前的版本: 虽然这段代码看上去也挺简单的,但想象一下如果你要给大量...

  • ECMAScript 6 - 变量的解构赋值

    概述 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这称为解构(Destructuring) 在E...

  • ECMAScript 6 变量的解构赋值

    ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。 数组...

  • 《ECMAScript 6 入门》变量解构赋值

    基本语法 可以写成: 只要等号两边的模式相同,左边变量就会被赋予对应的值。 如果解构不成功,变量的值就等于 und...

  • ES6概念总结.md

    ECMAScript 6 Part1 let与const声明变量,作用域有所不同 变量解构赋值,不规则格式一一智能...

  • 解构赋值

    解构赋值:ES6 中新增了变量赋值的方式,从数组和对象中提取值,对变量进行赋值。 单独赋值给变量,解构赋值。 解构...

  • ECMAScript6变量的解构赋值

    数组的解构赋值 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuri...

  • ECMAScript 6 入门--let、const和变量解构

    ECMAScript 6 入门--let、const和变量解构 《ECMAScript 6 入门》 购买 ES6...

  • ES6笔记(解构赋值)

    ES6笔记(解构赋值) 解构赋值 变量的解构: 解构赋值允许指定默认值。 解构赋值必须保证赋值方 被赋值方类型一...

  • ES6

    ES6: ES6 新语法 1.变量 解构赋值 (解构赋值对应的python里的序列解包) 解构赋值方式一: 解构赋...

网友评论

    本文标题:ECMAScript 6 变量的解构赋值

    本文链接:https://www.haomeiwen.com/subject/jemzkctx.html