前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >箭头函数与普通函数的区别

箭头函数与普通函数的区别

作者头像
老九君
发布于 2022-08-26 06:23:49
发布于 2022-08-26 06:23:49
7350
举报
文章被收录于专栏:老九学堂老九学堂

说到箭头函数和普通函数的区别,大家都一定会觉得这是一道高频面试题,但许多人其实对它们的理解还不够到位,今天我就来帮大家打造一个更清晰的认知。

01 

【从定义方式来看】

【普通函数】

定义普通函数的方式通常有函数声明和函数表达式:

【箭头函数】

箭头函数是普通函数的语法糖(使用语法糖能够增加程序的可读性,从而减少程序代码出错的机会),书写要更加简洁:

02

【从this指向来看】

【普通函数】

严格模式下,this指向undefined:

非严格模式下,this指向window:

谁调用函数,函数内部的this就指向谁:

普通函数中的this指向是动态的:

从上面的例子可以看出,fn函数中的this本应指向window,后面我们通过bind方法将函数的this指向改变为了obj对象,所以打印出obj。

可以看出,普通函数的this指向可以通过bind、call、apply等方法进行改变,this指向是动态的

【箭头函数】

无论是严格模式还是非严格模式下,this始终指向window:

箭头函数没有自己的执行上下文,this指向是在定义函数时就被确定下来的,箭头函数中的this,永远指向外层作用域中最接近自己的普通函数的this:

从上面的例子中可以看出,普通函数fn作为obj的属性被调用,谁调用普通函数,那么函数中的this就指向谁,所以fn的this指向obj。

fn函数内部有一个箭头函数test,test没有自己的this,它的this指向外层作用域中最接近自己的普通函数的this,所以test中的this也指向obj。

箭头函数会忽略任何形式的this指向的改变(bind、call、apply等方式无法改变箭头函数的this指向),箭头函数的this指向是静态的

03

【从构造函数来看】

【普通函数】

通过new关键字调用普通函数(作为构造函数),this指向被创建出来的对象实例:

【箭头函数】

箭头函数不能当做构造函数来使用:

04

【从arguments对象来看】

【普通函数】

在普通函数中,arguments是类数组对象,保存着函数执行时传入的参数:

【箭头函数】

箭头函数没有arguments:

05

【补充】

  • 箭头函数没有prototype属性
  • 箭头函数不能当做Generator函数,不能使用yield关键字
  • 箭头函数不能被new关键字调用,不具有new.target

阅读原文

了解老九学堂暑期线下就业班详情

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-08-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 老九学堂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
热点面试题:箭头函数与普通函数的区别?
前端小菜鸡一枚,分享的文章纯属个人见解,若有不正确或可待讨论点可随意评论,与各位同学一起学习~
沉浸式趣谈
2024/03/13
1210
热点面试题:箭头函数与普通函数的区别?
你知道多少this,new,bind,call,apply?那我告诉你
那么什么是this,new,bind,call,apply呢?这些你都用过吗?掌握这些内容都是基础中的基础了。如果你不了解,那还不赶快去复习复习,上网查阅资料啥的!
达达前端
2019/11/14
3880
箭头函数与普通函数的区别详解[通俗易懂]
二.箭头函数都是匿名函数 普通函数可以有匿名函数,也可以有具体名函数,但是箭头函数都是匿名函数。 代码实例如下:
全栈程序员站长
2022/09/14
9100
JavaScript 设计模式学习第二篇-关于this、new、bind、call、apply
虽然标题关于this、new、bind、call、apply,但实际上这些都离不开 this,因此本文将着重讨论 this,在此过程中分别讲解其他知识点。
越陌度阡
2020/11/26
2950
前端面试比较好的回答
DNS占用53号端口,同时使用TCP和UDP协议。 (1)在区域传输的时候使用TCP协议
loveX001
2022/11/09
1.1K0
js中this指向问题及call,apply,bind的区别
在标准函数中,this 指向的是把函数当成方法调用的上下文对象。也就是说在哪里调用的这个函数,那这个this只会指向它外面最靠近它的对象。
潜心专研的小张同学
2023/01/03
1.2K0
js中this指向问题及call,apply,bind的区别
七、this
我们在学习JavaScript的过程中,由于对一些概念理解得不是很清楚,但是又想要通过一些方式把它记下来,于是就很容易草率的给这些概念定下一些方便自己记忆的有偏差的结论。
用户6901603
2020/07/27
3240
七、this
this的理解
在JavaScript中,this 这个特殊的变量是相对比较复杂的,因为this不仅仅用在面向对象环境中,在其他任何地方也是可用的。
Yerik
2021/07/26
5371
你真的了解ES6函数特性么?
hello大家好,又见面了。 假期转瞬即逝,年后开工的第一天,早上是真的不想起床吖,为了不迟到闭着眼睛就穿衣服。 好啦好啦,步入正题啦,打起精神哦!
JowayYoung
2021/04/30
4530
彻底弄清 this call apply bind 以及原生实现[2019-3-12更新]
有关 JS 中的 this、call、apply 和 bind 的概念网络上已经有很多文章讲解了 这篇文章目的是梳理一下这几个概念的知识点以及阐述如何用原生 JS 去实现这几个功能
JS菌
2019/04/10
3820
彻底弄清 this call apply bind 以及原生实现[2019-3-12更新]
JS 语法糖 1 —— 箭头函数
从 ECMAScript 6 开始,JS 新增了一种新的函数:箭头函数(Arrow Function)。
恋喵大鲤鱼
2021/02/22
2K0
ES6 系列之箭头函数
很多时候,你可能想不到要这样用,所以再来举个例子,比如在 React 与 Immutable 的技术选型中,我们处理一个事件会这样做:
夜尽天明
2019/06/28
4680
JavaScript 高级程序设计(第 4 版)- 函数
函数实际上是对象。每个函数都是Function类型的实例,Function也有属性和方法。函数名就是指向函数对象的指针。 # 箭头函数 只有一个参数可以不用括号,只有没有参数、或多个参数的情况下,才需要使用括号 箭头函数可以不用大括号,会隐式返回箭头后面那行代码的值 箭头函数不能使用arguments、super和new.target,也不能作为构造函数 箭头函数没有prototype属性 # 函数名 函数名就是指向函数的指针 使用不带括号的函数名会访问函数指针,而不会执行函数 所有函数对象都会暴露一个只读
Cellinlab
2023/05/17
3880
JavaScript 高级程序设计(第 4 版)- 函数
重学 this 关键字(看完不全懂您找我哦)
1. 面试会问啊!总有一些面试官喜欢问你一段不可能这么写的代码。看一道经典且古老的面试题(学完本文后,文末会有一道更复杂的面试题等着你哦!)
coder_koala
2019/09/10
5110
重学 this 关键字(看完不全懂您找我哦)
论普通函数和箭头函数的区别以及箭头函数的注意事项、不适用场景
箭头函数是ES6的API,相信很多人都知道,因为其语法上相对于普通函数更简洁,深受大家的喜爱。就是这种我们日常开发中一直在使用的API,大部分同学却对它的了解程度还是不够深...
OBKoro1
2019/03/27
1.6K0
论普通函数和箭头函数的区别以及箭头函数的注意事项、不适用场景
一文读懂Js中的this指向
this关键字是一个非常重要的语法点。毫不夸张地说,不理解它的含义,大部分开发任务都无法完成。
hellocoder2029
2022/10/10
9500
彻底弄清 this call apply bind 以及原生实现
有关 JS 中的 this、call、apply 和 bind 的概念网络上已经有很多文章讲解了 这篇文章目的是梳理一下这几个概念的知识点以及阐述如何用原生 JS 去实现这几个功能
JS菌
2019/04/10
4170
彻底弄清 this call apply bind 以及原生实现
apply/call/bind、作用域/闭包、this指向(普通,箭头,JS/Vue的this)
这里要跟this指向区分开。(这里说的作用域先简单理解为,只是变量的作用域,跟this没关系)
用户4396583
2024/10/08
1220
js this问题和es6箭头函数this问题
4.apply 调用 ,apply方法作用是改变函数的调用对象,此方法的第一个参数为改变后调用这个函数的对象,this指代第一个参数
yaphetsfang
2020/07/30
1.3K0
普通函数与箭头函数
这里的this指向的是对象o,因为你调用这个fn是通过o.fn()执行的,那自然指向就是对象o。
愤怒的小鸟
2021/01/20
9860
推荐阅读
相关推荐
热点面试题:箭头函数与普通函数的区别?
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文