一、箭头函数的基本用法
(1)当函数只有一个参数的情况下
data => data
等价于
function(data){
return data;
}
(2)当函数“没有”参数或“有多个”参数的情况下
() => 5
等价于
function(){
return 5;
}
注:如果箭头函数的代码块多于一条语句,就要用大括号将它们括起来
(data1,data2) => {
let result = data1 + data2;
return result;
}
等价于
function(data1,data2){
let result = data1 + data2;
return result;
}
注:由于在箭头函数中,“{}”里的内容都会被解释为代码块(js会解释并运行),所以要是箭头函数直接返回一个“对象{}”,在返回的对象外面要用一个“()”来包住
例:() => ({first:" ",last:" "}) 该箭头函数返回的是一个{first:" ",last:" "}对象
二、箭头函数使用的注意事项
(1)箭头函数体内的this对象,就是声明该箭头函数时所在的对象(即this指向箭头函数声明时的父元素,指向父级作用域的上下文),而不是使用时所在的对象。
(2)不可以用作构造函数使用。
住:箭头函数this指向的固定化(即:指向箭头函数声明时的父元素),原因是因为箭头函数内部没有this,导致箭头函数的内部this就是外层代码块的this(解释了(1))。由于箭头函数没有this,所以就不可以用作构造函数(解释了(2))。
(3)下列变量的构造在箭头函数里是不可的:arguments,super,this,new.target
三、箭头函数和常规函数的比较
(1)箭头函数的this永远是指向声明该箭头函数时所在的对象(即this指向箭头函数声明时的父元素)
but 常规函数this指向的是使用时所在的对象,所以常规函数常常需要在函数内用一个变量保存“声明函数时对象”的this值,而箭头函数就不用。
例:var myObj = {
id:"sgfdga",
//es5写法
fun1:function(){
var _this = this;
return _this.id;
}
//es6写法
fun1:() => this.id
}
(2)箭头函数不可以用坐构造函数使用,but常规函数可以。
例:new (() => {}) 会报错