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对象,这点和在对象方法中定义有点像