前天在阿里淘宝的电话面试中被问到箭头函数和普通函数的区别,没能回答全面,现进行总结以下:git
ES6标准新增了一种新的函数:Arrow Function(箭头函数),为何叫Arrow Function?由于它的定义用的就是一个箭头,那么,它和普通函数有哪些不一样呢?github
箭头函数至关于匿名函数,而且简化了函数定义。箭头函数有两种格式,一种只包含一个表达式,连{ ... }和return都省略掉了。还有一种能够包含多条语句,这时候就不能省略{ ... }和return。面试
- 函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。
- 把动态this转换为静态this:长期以来,JavaScript 语言的this对象一直是一个使人头痛的问题,在对象方法中使用this,必须很是当心。箭头函数”绑定”this,很大程度上解决了这个困扰。
- 箭头函数可让this指向固定化,这种特性颇有利于封装回调函数。
- 原理: this指向的固定化,并非由于箭头函数内部有绑定this的机制,实际缘由是箭头函数根本没有本身的this,致使内部的this就是外层代码块的this。正是由于它没有this,因此也就不能用做构造函数。
缘由:构造函数的new都作了些什么?简单来讲,分为四步
不可使用arguments对象,该对象在函数体内不存在。若是要用,能够用 rest 参数代替。想要在箭头函数中以相似数组的形式取得全部参数,能够利用展开运算符来接收参数,好比:
const testFunc = (...args)=>{ console.log(args) //数组形式输出参数 }
在 ECMAScript 6 以前的函数声明中,它们的参数都是“简单参数类型”的。在 ECMAScript 6 以后,凡是在参数声明中使用了缺省参数、剩余参数和模板参数之一的,都再也不是“简单的”(non-simple parameters)。在使用传统的简单参数时,只须要将调用该参数时传入的实际参数与参数对象(arguments)绑定就能够了;而使用“非简单参数”时,须要经过“初始器赋值”来完成名字与值的绑定。数组
两种绑定模式的区别在于:一般将实际参数与参数对象绑定时,只须要映射两个数组的下标便可,而“初始器赋值”须要经过名字来索引值(以实现绑定),所以一旦出现“重名参数”就没法处理了。app
因为 this 已经在词法层面完成了绑定,经过 call()、 apply()、bind() 方法调用一个函数时,只传入了一个参数,对 this 并无什么影响
若是要直接返回对象时须要用小括号包起来,由于大括号被占用解释为代码块了
转换前:函数
// ES6 const obj = { getArrow() { return () => { console.log(this === obj); }; } }
转换后:this
// ES5,由 Babel 转译 var obj = { getArrow: function getArrow() { var _this = this; return function () { console.log(_this === obj); }; } };
我的博客地址prototype