ES6系列——之箭头函数(四)

ES6新加入了一种函数声明方式,即箭头函数=>,在此之前我们使用function关键字来声明函数。下面我们将说说关于箭头函数的使用和注意事项。


举个例子

传统的ES5写法:

  1. function a(){
  2. //content
  3. }

ES6写法:

  1. let a = () =>{
  2. //content
  3. }

以上两个函数等价。同时,我们可以将传统的写法:

  1. var fun = {
  2. getFunfunction(){
  3. return a;
  4. },
  5. setFunfunction(val){
  6. console.log(val)
  7. }
  8. }

ES6改写:

  1. let fun = {
  2. getFun(){
  3. return a;
  4. },
  5. setFun(val){
  6. console.log(val)
  7. }
  8. }

注意

  • 函数体内的this对象就是定义时所在的对象,而不是使用时所在的对象。
  • 不可以当做构造函数,也就是说,不可以使用new命令,否则报错。
  • 不可以使用arguments对象,该对象在函数体内不存在,如果要用,可以使用rest参数代替。
  • 不可以使用yield命令,因此箭头函数不能用作generator函数。
  • 第一点尤其注意,this对象的指向是可以改变的,但是在箭头函数中它是固定的。

评论: