什么是箭头函数_它与普通函数有何区别?

箭头函数是ES6引入的简洁函数语法,无this绑定、不可实例化、无arguments,适用于短回调;普通函数具备完整动态特性,适用于需this控制或构造场景。

什么是箭头函数_它与普通函数有何区别?

箭头函数是 ES6 引入的一种函数定义方式,用 => 符号代替 function 关键字,语法更紧凑,适合写短小逻辑或回调。但它不是普通函数的简单“简写”,而是有本质差异的设计。

语法更简洁,但限制更多

箭头函数省略 function、可省括号(单参数时)、可省花括号和 return(单表达式时):

const square = x => x * x —— 比 function(x) { return x * x; } 少一半字符无参数写 () => Date.now();多参数必须加括号:(a, b) => a + b多行逻辑需显式写 {}returnx => { console.log(x); return x * 2; }它只能是表达式,不支持函数声明(不能提升),也不能重名赋值

this 指向完全不一样

这是最常踩坑的一点:箭头函数没有自己的 this,它直接继承外层作用域this,且无法更改。

普通函数的 this 在调用时才确定,谁调用就指向谁(如对象方法、事件处理器new 实例等)箭头函数的 this 在定义时就锁死,之后无论怎么调用、用 .call().bind() 都无效在对象方法中误用箭头函数,this 往往指向全局或外层函数,而不是当前对象

缺少普通函数的关键特性

箭头函数被有意设计为“轻量工具”,因此主动舍弃了一些面向对象和动态执行的能力:

不能用 new 调用 —— 它没有 prototype,也不配做构造函数没有 arguments 对象 —— 需用剩余参数 ...args 替代没有 supernew.target,也不能作为 Generator(不支持 yield)永远是匿名的(即使赋值给变量,fn.name 为空字符串)

基本上就这些。选哪个函数,关键看场景:要绑定 this、要实例化、要动态参数处理,就用普通函数;写个简单映射、过滤、回调,又不想管 this 绑定,箭头函数更干净利落。

以上就是什么是箭头函数_它与普通函数有何区别?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1543288.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 14:55:21
下一篇 2025年12月21日 14:55:32

相关推荐

发表回复

登录后才能评论
关注微信