ES6的箭头函数与普通函数到底有何渊源

北京白癜风防治医院 https://jbk.39.net/yiyuanzaixian/bjzkbdfyy/

刚开始找实习工作的时候,就时常被面试官问到“箭头函数与普通函数有什么区别?”,一开始也是简单说其区别,但事情的本质往往并不是表面上那么简单,那么,接下来我们就看看他们俩到底有何渊源。

在我们日常编写js的习惯中,我们定义一个函数时,往往会用以下几种方式

1.函数声明`

functionfunctionName(arg){

//执行代码

2.函数表达式

varfunctionName=function(arg){

//执行代码

3.箭头函数

varfunctionName=(arg)={

//执行代码

}

这几种方式有什么区别呢?

前两种是es6之前的语法,函数声明的重要特性是函数声明提升,意思是在执行代码前会先读取函数声明,意味着可以把函数声明放在调用它的语句之后;而函数表达式创建的函数叫做匿名函数,因为function关键字后面没有标识符(也叫做拉姆达函数),而函数表达式与函数声明之间的区别就在于函数提升(函数表达式是不会函数提升的,至于为什么不会,之后再另行分析)

而第三种则是ES6标准新增了一种新的函数:ArrowFunction(箭头函数),为什么叫ArrowFunction?因为它的定义用的就是一个箭头

那么,它和之前的函数有哪些不同呢?

1.箭头函数不会创建自己的this

MDN上对箭头函数this的解释。

箭头函数不会创建自己的this,所以它没有自己的this,它只会从自己的作用域链的上一层继承this。

箭头函数没有自己的this,它会捕获自己在定义时(注意,是定义时,不是调用时)所处的外层执行环境的this,并继承这个this值。所以,箭头函数中this的指向在它被定义的时候就已经确定了,之后永远不会改变。

2.函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。

3.call(),apply(),bind()无法改变箭头函数中this的指向

.call.apply.bind方法可以用来动态修改函数执行时this的指向,但由于箭头函数的this定义时就已经确定且永远不会改变。所以使用这些方法永远也改变不了箭头函数this的指向,虽然这么做代码不会报错。

长期以来,JavaScript语言的this对象一直是一个令人头痛的问题,在对象方法中使用this,必须非常小心。箭头函数”绑定”this,很大程度上解决了这个困扰。

4.箭头函数是匿名函数,不能作为构造函数,不可以使用new命令,否则会抛出一个错误。所以箭头函数也不具有new.target。

new都做了些什么?简单来说,分为四步:

①JS内部首先会先生成一个对象;

②再把函数中的this指向该对象;

③然后执行构造函数中的语句;

④最终返回该对象实例。

因为箭头函数没有自己的this,它的this其实是继承了外层执行环境中的this,且this指向永远不会随在哪里调用、被谁调用而改变,所以箭头函数不能作为构造函数使用,或者说构造函数不能定义成箭头函数,否则用new调用时会报错!

5.箭头函数不绑定arguments,取而代之用rest参数…解决;所以箭头函数也没有arguments.callee和arguments.caller

不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用rest参数代替。想要在箭头函数中以类似数组的形式取得所有参数,可以利用展开运算符来接收参数,比如:

constfunctionName=(...args)={

console.log(args)//数组形式输出参数

}

6.箭头函数没有原型prototype,会得出undefined,不能简单返回对象字面量

如果要直接返回对象时需要用小括号包起来,因为大括号被占用解释为代码块了

不能使用yield关键字,因此箭头函数不能用作Generator函数。

箭头函数括号后面不能换行;

箭头函数不具有super。

最后:箭头函数的好处在于可以让this指向固定化,这种特性很有利于封装回调函数。

原理:this指向的固定化,并不是因为箭头函数内部有绑定this的机制,实际原因是箭头函数根本没有自己的this,导致内部的this就是外层代码块的this。正是因为它没有this,所以也就不能用作构造函数。




转载请注明:http://www.aierlanlan.com/grrz/3458.html

  • 上一篇文章:
  •   
  • 下一篇文章: 没有了