JavaScript 极简教程 ES6 ES7前端笔记让前端飞

ES6箭头函数

2018-11-16  本文已影响10人  六个周
箭头函数中的this指向的是定义时的this,而不是执行时的this

一、为什么要有箭头函数

先看如下代码;

const Person = {
'name': 'little bear',
'age': 18,
'sayHello': function () {
  setInterval(function () {
    console.log('我叫' + this.name + '我今年' + this.age + '岁!')
  }, 1000)
}
}
Person.sayHello()

上面的代码运行会是上面结果呢?
上例的输出结果是我叫undefined,今年我undefined岁。
这是因为setInterval执行的时候,是在全局作用域下的,所有this指向的是全局window,而window上没有name和age,所以当然输出的是undefined咯。

那么,我们怎么要解决这个问题呢?
通常的写法是缓存this,然后在setInterval中用缓存的this进行操作,如下

const Person = {
'name': 'little bear',
'age': 18,
'sayHello': function () {
 let self = this
  setInterval(function () {
    console.log('我叫' + self.name + '我今年' + self.age + '岁!')
  }, 1000)
}
}
const sayHelloFun = Person.sayHello
sayHelloFun()

明明是写在对象里面的方法,为什么还要使用缓存这个对象才能正确使用?
于是在es6的新特性里添加了箭头函数,它能很好的解决这个问题。

二 什么是箭头函数

function(){
    console.log('hello')
}

向上面的方法写成箭头函数后是这样的:

()=> conosle.log('hello')

三、和普通函数的区别

主要是两方面的优势:
①不绑定this,arguments
②更简化的代码语法。

3.1不绑定this

不绑定this的意思就是说:箭头函数的this是在定义的时候就确定好的,以后不管怎样调用箭头函数,箭头函数的this始终未定义的this

3.2不绑定arguments

箭头函数还有一个比较有特点的地方就是其不绑定arguments,即如果你在箭头函数中使用arguments参数不能得到想要的内容。

四、什么时候不能使用箭头函数

前面我们已经看到了很多关于es6箭头函数的好处,也看到了箭头函数的一些不足。那么我们应该在什么时候使用箭头函数,而什么时候最好不要使用呢?
1.作为对象的方法
最好不要在对象的方法中使用箭头函数,这样可能会导致一些问题的产生。除非你很熟悉箭头函数。
2.不能作为构造函数
由于箭头函数的this不绑定的特点,所以不能使用箭头函数作为构造函数,实际上如果这样做了,也会报错。
3.定义原型方法

function Person (name){
    this.name = name
}
Person.prototype.sayHello = () => {
    console.log(this)
}
var p1 = new Person()
p1.sayHello()
//output 
window对象

这里的this指向的是window对象,这点和在对象方法中定义有点像

上一篇下一篇

猜你喜欢

热点阅读