ES6箭头函数

一、箭头函数的基本用法

(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 (() => {}) 会报错

你可能感兴趣的:(ES6箭头函数)