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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 箭头符号在JavaScript诞生时就已经存在,当初第一个JavaScript教程曾建议在HTML注释内包裹行内脚...
    程序员之路阅读 767评论 0 3
  • 参考: http://es6.ruanyifeng.com/?search=%E7%AE%AD%E5%A4%B4&...
    TingsLee阅读 495评论 0 1
  • 函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。请看下面这个例子: 输出undefined是...
    zenggo阅读 1,057评论 0 50
  • 箭头函数是什么?(What) 箭头函数 (Arrow Functions)也称“胖箭头函数”,是ES6全新的特性。...
    _LG_阅读 3,496评论 2 11
  • 有一种慢性皮肤病叫湿疹 慢性湿疹诊状是显红疹状,伴有骚痒,如果忍不住去抓的话会水泡,时间长了皮肤层会增厚,我得这种...
    自律就是自由阅读 266评论 0 0