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

1次阅读

箭头函数是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,且无法更改。

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

Veo

Google 最新发布的 AI 视频生成模型

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

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

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

缺少普通函数的关键特性

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

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

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

text=ZqhQzanResources