箭头函数 () =>{} || =>
箭头函数书写简便,大大简化了编程的繁琐操作,更适合于函数式编程。
除此之外,箭头函数最大的特性是没有自己的this,也没有普通函数自动绑定的arguments等属性,因为箭头函数首先是一个匿名函数,因此一般是在作为回调出现,所以箭头函数的this指向的是函数的定义者,而非调用者,所以使用call() apply() 或者bind()等方法绑定箭头函数的this是无s效的。
箭头函数的写法就是小括号+箭头+花括号,若没有参数也可省略小括号。
=> / ()=>{}/ =>{}
rest参数
es6引入了rest参数,即我们常见的三个点 ...params ,rest参数与一个变量名搭配使用,用来获取多余的参数,这些参数会组成一个数组,值得注意的是,rest参数必须是作为最后一个参数传入 ,否则将报错。
例如 function(param1,param2,param3,param4){} =>function(...params){}
...params = [param1,param2,param3,param4]
es6的插值 ${}
写法:${},插值就是我们在es6之前的语法中的字符串拼接的功能,这一写法也是现在插入数据的主要写法,例如angular和vue的主流框架在文本中插入数据就是使用的双大括号{{}},插值就是“”+“”的简写的方式,等同于${item}${index},插值大括号里面不仅能够放变量,还可以进行数据计算,或是变量的转译 ${var a as item}
类 class
es6中引入了类的概念,类的引入使得js具有了块级作用域,在class包裹中的函数作用域是一个独立的上下文模块域。
使用方法也很简单,定义一个模块作为一个类,声明其中的构造函数construtor,并声明其中的私有属性private或公属性public
这一点上js也越来越向java靠拢,其中也有super关键字,唯一的区别在于类里面的写法是js的语法,。
既然引入了类,那么继承的方式也从java借鉴过来了,以往。js的继承就是让一个子构造函数的原型指向父构造函数的实例,然后在该子构造函数的内部声明该构造函数的指向,这种继承方式太过麻烦,又显得很冗余,所以es6中提供extends关键字,作为实现继承的方式,使用方式也是和java里的写法一样,class A extends class B(...params){}
es6的语法es5中的差异差不多就是上述这些,但是基本的思想是不变的,变的不过是外在的形式,但是我们说,所有的变化都是为了更好的服务我们的工作。保持努力,努力向前。