ES6新增了关于变量的定义,函数扩展,数据结构,类,模块等概念,本文详细介绍常用的ES6语法。
ES6之变量的定义
let定义变量
块级作用域
ES6中新增了let语法,用来声明变量,用法类似var,但是使用let定义的变量,只在当前代码块内有效。
1 | <!DOCTYPE html> |
ES5只有全局作用域和函数作用域, 没有块级作用域, 如下代码所示。所以下面代码中的var变量定义会被提示到函数作用域顶端,所以如下代码:
1 | <!DOCTYPE html> |
在以上代码中的var修改为let,即可避免全局变量username被if代码块中的username替代。还有一种情况,使用var定义变量时,用来计数的循环变量会泄露为全局变量,如下代码所示:
1 | <!DOCTYPE html> |
同样的,我们可以使用let定义变量,使得循环变量只在当前代码块生效,如下代码所示:
1 | <!DOCTYPE html> |
变量提升
在ES5或者更早的版本,我们使用var定义变量,使用该语法定义变量时,JavaScript引擎默认会将函数及变量的定义提升到代码块顶端,也就是说,除了在函数中定义的变量会被提升到函数作用域顶端外,在其他地方定义的变量,都会被定义在全局。
1 | <!DOCTYPE html> |
如上所述,var定义变量会发生“变量提升”现象,即变量可以在声明之前使用,值为“undefined”,这不符合大多数编程语言的规范,也会多多少少带来一些问题。为了解决这个问题,ES6中引入了let命令,使用let定义的变量,必须在声明之后才能使用,否则报错。
1 | <!DOCTYPE html> |
不能重复定义
1 | <!DOCTYPE html> |
const定义变量
定义后不能修改
const关键字声明一个只读常量,常量一旦被声明,就不能被更改。
1 | <!DOCTYPE html> |
声明时赋值
const声明的变量,必须在声明时赋值,不能声明之后赋值,否则会报错。
1 | <!DOCTYPE html> |
不能重复定义
与let命令一样,使用const定义的常量,不能重复定义,不存在变量提升,并只在当前作用域有效。
1 | <!DOCTYPE html> |
const的可变与不可变
使用const定义的常量,不可改变,这里的不可改变,指的是该数据类型本身不可改变,比如字符串,数字,假设使用const定义一个对象或者数组,因为对象和数组这两种数据类型本身是可以被新增或者删除元素的,所以,此时const定义的常量可以被改变。
const实际上保证的,并不是变量的值不可改变,而是变量指向的那个内存地址所保存的数据不得改动。对于简单类型的数据(数值、字符串、布尔值),值就保存在变量指向的那个内存地址,因此等同于常量。但对于复合类型的数据(比如对象和数组),变量指向的内存地址,保存的只是一个指向实际数据的指针,const
只能保证这个指针是固定的(即总是指向另一个固定的地址),至于它指向的数据结构是不是可变的,就完全不能控制了。因此,将一个对象声明为常量必须非常小心。
1 | <!DOCTYPE html> |
ES6之模板字符串
反引号和${}的使用
在ES5中,字符串拼接我们使用“+”号,ES6中新增了一种方式,叫做模板字符串,下面我们来使用该功能进行字符串的拼接
1 | <!DOCTYPE html> |
ES6之数据解构
迭代访问数组和对象
在ES5中,我们访问数组或者对象的数据只能一个个访问,但是在ES6中我们可以使用数据的解构。
1 | <!DOCTYPE html> |
ES6之函数的扩展
默认值参数
在ES5中,由于函数不支持设置默认值,所以当遇到需要设置默认值的情况的时候,只能采用变通的方式,不过这种变通的方式会存在一些问题。ES6中引入了函数的默认值参数,解决了这些问题。
1 | <!DOCTYPE html> |
箭头函数
ES6中引入了箭头函数,其实就相当于Python当中的匿名函数lambda,接下来我们详细看看箭头函数的使用方式以及使用箭头函数时需要注意的地方。
箭头函数的定义
1 | // 箭头函数的定义 |
一个或者多个参数的函数定义方式如下:
1 | // 零个参数或者多个参数的箭头函数定义方式如下 |
如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return
语句返回:
1 | // 如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return语句返回 |
箭头函数的用途
那么,箭头函数有什么用呢?其一,箭头函数可以简化代码,是代码实现更加简洁,比如如下需求:
1 | // 判断一个数是否是偶数 |
另外,箭头函数还可以简化回调函数的写法,比如,map和sort中的回调函数
1 | // 箭头函数可以简化回调函数 |
箭头函数有如此多的妙处,那么我们使用它的时候有哪些需要注意的地方呢?
箭头函数的this指向问题
首先,箭头函数中的this不再随着调用它的对象的改变而改变,this对象变成固定的了,它稳定的指向该箭头函数被定义时的作用域,而不是像普通函数那样,指向函数调用时的作用域。
1 | <!DOCTYPE html> |
下面的代码中this对象指向该箭头函数定义时所在的作用域
1 | <!DOCTYPE html> |
这是一个非常重要的不同点,也是vue.js中比较常用的一个知识点。
ES6之类的定义
ES5实例化对象的方式
ES5中的我们常使用构造函数的方式,创建一个实例对象,比如如下示例
1 | <!DOCTYPE html> |
ES6实例化对象的方式
ES6给我们引入了class关键字,我们可以使用class关键字来创建一个类
1 | <!DOCTYPE html> |
类的继承
同样的,我们也可以使用类的继承
1 | <!DOCTYPE html> |
以上就是ES6常用语法介绍。