精简的函数快递员
想象箭头函数是一位高效的快递员,用最短路径(=>)传递数据
function add(a, b) {
  return a + b;
}
const add = (a, b) => a + b;  
console.log(add(1,  2)); 
精简规则
单参数可省括号
const sayHi = name => `你好, ${name}!`;  
sayHi("小明"); 
单行代码自动返回(无{}时)
const double = num => num * 2; 
返回对象需加括号(避免与{}冲突)
const getUser = id => ({ id: id, name: "匿名" });
永不迷路的 this
箭头函数最强大的特性——继承外层 this 值,解决传统函数的 this 混乱问题
const obj1 = {
  name: "对象1",
  print: function() {
    setTimeout(function() {
      console.log(this.name);  
    }, 100);
  }
};
const obj2 = {
  name: "对象2",
  print: function() {
    setTimeout(() => {
      console.log(this.name);  
    }, 100);
  }
};
箭头函数就像带着GPS的快递员,永远记得出发地(定义时的作用域),不因中转站(调用位置)改变路线
一般常见的使用场景
简化回调函数
[1, 2, 3].map(function(x) { return x * x; });
[1, 2, 3].map(x => x * x); 
操作数组方法
const sum = [1, 2, 3].reduce((total, num) => total + num, 0); 
固定 this 的场景(如事件监听)
button.addEventListener("click",  () => {
  console.log(this);  
});
箭头函数 vs 普通函数
| 特性 | 箭头函数 | 普通函数 | 
|---|
| this指向 | 继承定义时的外层作用域 | 由调用者决定 | 
| 构造函数 | ❌ 不可用 | ✅ 可用 | 
| arguments对象 | ❌ 不可用 | ✅ 可用 | 
| 简洁性 | ⭐⭐⭐⭐ 极高 | ⭐⭐ 较低 | 
牢记
“箭头函数像快递:路线短(语法简),认准出发地(this稳),不接大件货(无构造)。”
转自https://juejin.cn/post/7546445334568468507
该文章在 2025/9/6 17:24:48 编辑过