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

箭头函数是 ES6 引入的一种函数定义方式,用 => 符号代替 function 关键字,语法更紧凑,适合写短小逻辑或回调。但它不是普通函数的简单“简写”,而是有本质差异的设计。
语法更简洁,但限制更多
箭头函数省略 function、可省括号(单参数时)、可省花括号和 return(单表达式时):
-
const square = x => x * x—— 比function(x) { return x * x; }少一半字符 - 无参数写
() => date.now();多参数必须加括号:(a, b) => a + b - 多行逻辑需显式写
{}和return:x => { console.log(x); return x * 2; } - 它只能是表达式,不支持函数声明(不能提升),也不能重名赋值
this 指向完全不一样
这是最常踩坑的一点:箭头函数没有自己的 this,它直接继承外层作用域的 this,且无法更改。
- 普通函数的
this在调用时才确定,谁调用就指向谁(如对象方法、事件处理器、new实例等) - 箭头函数的
this在定义时就锁死,之后无论怎么调用、用.call()或.bind()都无效 - 在对象方法中误用箭头函数,
this往往指向全局或外层函数,而不是当前对象
缺少普通函数的关键特性
箭头函数被有意设计为“轻量工具”,因此主动舍弃了一些面向对象和动态执行的能力:
- 不能用
new调用 —— 它没有prototype,也不配做构造函数 - 没有
arguments对象 —— 需用剩余参数...args替代 - 没有
super、new.target,也不能作为 Generator(不支持yield) - 永远是匿名的(即使赋值给变量,
fn.name为空字符串)
基本上就这些。选哪个函数,关键看场景:要绑定 this、要实例化、要动态参数处理,就用普通函数;写个简单映射、过滤、回调,又不想管 this 绑定,箭头函数更干净利落。