12-27.ES6

105 阅读1分钟

let 和 const 命令:

image.png

image.png

image.png

image.png

4.顶层对象的属性:

顶层对象,在浏览器环境指的是window对象,在 Node 指的是global对象。ES5 之中,顶层对象的属性与全局变量是等价的。

image.png

image.png

1.数组的解构赋值:

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

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

image.png

image.png

image.png

image.png

6.圆括号问题:

解构赋值虽然很方便,但是解析起来并不容易。对于编译器来说,一个式子到底是模式,还是表达式,没有办法从一开始就知道,必须解析到(或解析不到)等号才能知道。

由此带来的问题是,如果模式中出现圆括号怎么处理。ES6 的规则是,只要有可能导致解构的歧义,就不得使用圆括号。

但是,这条规则实际上不那么容易辨别,处理起来相当麻烦。因此,建议只要有可能,就不要在模式中放置圆括号。

image.png

image.png

7.用途:

(1)交换变量的值

(2)从函数返回多个值

函数只能返回一个值,如果要返回多个值,只能将它们放在数组或对象里返回。有了解构赋值,取出这些值就非常方便。

(3)函数参数的定义

解构赋值可以方便地将一组参数与变量名对应起来。

(4)提取 JSON 数据

解构赋值对提取 JSON 对象中的数据,尤其有用。

image.png