极简三分钟ES6 - 箭头函数

精简的函数快递员

想象箭头函数是一位高效的快递员,用最短路径(=>)传递数据

js 复制代码
// 传统函数写法
function add(a, b) {
  return a + b;
}

// 箭头函数写法(直达路线)
const add = (a, b) => a + b;  
console.log(add(1,  2)); // 3(快递直达)

精简规则

单参数可省括号

js 复制代码
const sayHi = name => `你好, ${name}!`;  
sayHi("小明"); // "你好, 小明!"

单行代码自动返回 (无{}时)

js 复制代码
const double = num => num * 2; // 直接返回结果

返回对象需加括号 (避免与{}冲突)

js 复制代码
const getUser = id => ({ id: id, name: "匿名" });

永不迷路的 this

箭头函数最强大的特性------继承外层 this ,解决传统函数的 this 混乱问题

js 复制代码
// 传统函数:this 随调用者变化
const obj1 = {
  name: "对象1",
  print: function() {
    setTimeout(function() {
      console.log(this.name);  // 输出 undefined(this指向window)
    }, 100);
  }
};

// 箭头函数:继承定义时的 this
const obj2 = {
  name: "对象2",
  print: function() {
    setTimeout(() => {
      console.log(this.name);  // 输出 "对象2"(继承print的this)
    }, 100);
  }
};

箭头函数就像带着GPS的快递员,永远记得出发地(定义时的作用域),不因中转站(调用位置)改变路线

一般常见的使用场景

简化回调函数

js 复制代码
// 传统写法
[1, 2, 3].map(function(x) { return x * x; });

// 箭头函数版
[1, 2, 3].map(x => x * x); // [1, 4, 9]

操作数组方法

js 复制代码
const sum = [1, 2, 3].reduce((total, num) => total + num, 0); // 6

固定 this 的场景(如事件监听)

js 复制代码
button.addEventListener("click",  () => {
  console.log(this);  // 始终指向定义时的上下文
});

箭头函数 vs 普通函数

特性 箭头函数 普通函数
this 指向 继承定义时的外层作用域 由调用者决定
构造函数 ❌ 不可用 ✅ 可用
arguments 对象 ❌ 不可用 ✅ 可用
简洁性 ⭐⭐⭐⭐ 极高 ⭐⭐ 较低

牢记

"箭头函数像快递:路线短(语法简),认准出发地(this稳),不接大件货(无构造)。"

相关推荐
发现一只大呆瓜23 分钟前
虚拟列表:支持“向上加载”的历史消息(Vue 3 & React 双版本)
前端·javascript·面试
css趣多多40 分钟前
ctx 上下文对象控制新增 / 编辑表单显示隐藏的逻辑
前端
阔皮大师1 小时前
INote轻量文本编辑器
java·javascript·python·c#
lbb 小魔仙1 小时前
【HarmonyOS实战】React Native 表单实战:自定义 useReactHookForm 高性能验证
javascript·react native·react.js
_codemonster1 小时前
Vue的三种使用方式对比
前端·javascript·vue.js
寻找奶酪的mouse1 小时前
30岁技术人对职业和生活的思考
前端·后端·年终总结
梦想很大很大1 小时前
使用 Go + Gin + Fx 构建工程化后端服务模板(gin-app 实践)
前端·后端·go
We་ct1 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
张3蜂1 小时前
深入理解 Python 的 frozenset:为什么要有“不可变集合”?
前端·python·spring
无小道1 小时前
Qt——事件简单介绍
开发语言·前端·qt