内容简介:大家都知道箭头函数是es6新增的函数声明方式,当然普通函数还是可以继续使用的。我以前一直只知道箭头函数只对this指向有影响,但是没法说清楚具体有哪些影响,因此今天来总结整理一下。1.普通函数的this指向当前调用者对象。箭头函数的this指向其上下文2.箭头函数不能作为构造函数,所以也不能new,new就会报错。普通函数可以
大家都知道箭头函数是es6新增的函数声明方式,当然普通函数还是可以继续使用的。我以前一直只知道箭头函数只对this指向有影响,但是没法说清楚具体有哪些影响,因此今天来总结整理一下。
1.普通函数的this指向当前调用者对象。箭头函数的this指向其上下文
let obj={ a:function(){ console.log(this)//当前调用者 }, b:()=>{ console.log(this)//上下文 } } obj.a() obj.b()
2.箭头函数不能作为构造函数,所以也不能new,new就会报错。普通函数可以
3.箭头函数不能使用arguments,但可以使用...rest代替。rest参数也能在普通函数中使用,用于函数中传递不定参数
arguments是类数组,需要遍历进行使用。arguments和rest都必须写在最后面。
const A=(...a)=>{ console.log(a) } A(1,2,3,4)//数组 const B=function(){ console.log(arguments) } B(1,2,3,4)//类数组
4.箭头函数没有原型对象,普通函数有
//原型区别 const F=()=>{} const G=function(){} console.log(F.prototype)//undefined console.log(G.prototype)//原型对象
拓展知识:
1.call、apply、bind可以改变普通函数this指向,无法改变箭头函数的this指向
此处使用call后this就不是参数1的对象了,然后自动调用f函数。
apply:参数2传的是数组。bind:重新绑定对象,生成新的函数,需要重新调用
//改变this指向 const f=function(a){ console.log(this.name+a) } f()//undefined f.call({name:1},2)//3
这个this还是代表上下文,不是那个对象
const F=()=>{ console.log(this) } F.call({a:1})//window
以上所述就是小编给大家介绍的《前端笔记(关于箭头函数与普通函数的区别的理解)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
程序员修炼之道(影印版)
Andrew Hunt、David Thomas / 中国电力出版社 / 2003-8-1 / 39.00
本书直击编程陈地,穿过了软件开发中日益增长的规范和技术藩篱,对核心过程进行了审视——即根据需求,创建用户乐于接受的、可工作和易维护的代码。本书包含的内容从个人责任到职业发展,直至保持代码灵活和易于改编重用的架构技术。从本书中将学到防止软件变质、消除复制知识的陷阱、编写灵活、动态和易适应的代码、避免出现相同的设计、用契约、断言和异常对代码进行防护等内容。一起来看看 《程序员修炼之道(影印版)》 这本书的介绍吧!