JavaScript箭头函数是什么?区别详解
时间:2026-02-18 21:11:38 435浏览 收藏
JavaScript箭头函数是ES6引入的简洁语法糖,不仅大幅简化了函数书写(省略function关键字、return语句甚至括号),更在核心行为上与普通函数存在本质差异:它采用词法作用域绑定this(永远指向定义时外层普通函数的this,而非调用时上下文),不提供arguments对象(需用剩余参数替代),且不可作为构造函数使用(无法new调用、无prototype),这些特性使其在事件回调、异步操作中免去手动bind(this)的烦恼,但也限制了其在面向对象编程中的适用场景——理解这些区别,是写出健壮、可维护JavaScript代码的关键。

箭头函数是 ES6 引入的一种简洁的函数定义方式,用 => 符号表示。它不只是写法更短,更关键的是在 this 绑定、arguments、new 调用 等行为上和普通函数有本质区别。
语法更简洁,省略 function 关键字和 return(单表达式时)
箭头函数允许省略 function 关键字、括号(单参数时)、花括号和 return(单表达式返回值时)。
例如:
// 普通函数
const add = function(a, b) { return a + b; };
<p>// 箭头函数(等价写法)
const add = (a, b) => a + b;
const square = x => x * x; // 单参数可省括号
const log = () => console.log('hi'); // 无参必须写空括号</p>this 指向是词法绑定,不动态变化
普通函数的 this 取决于调用方式(谁调用,this 就是谁),而箭头函数没有自己的 this,它会沿作用域链向上找外层第一个普通函数的 this 值 —— 也就是“定义时”所在上下文的 this。
常见影响场景:
- 对象方法中使用箭头函数,
this不指向该对象,而是外层作用域(比如全局或构造函数) - 事件回调、定时器、Promise 回调中,用箭头函数可避免手动
bind(this)或缓存const self = this
没有 arguments、caller、callee
箭头函数内部访问不到 arguments 对象。如果需要类数组参数,应使用剩余参数(...args)代替。
例如:
function oldFn() {
console.log(arguments); // [1, 2, 3]
}
const newFn = () => {
console.log(arguments); // ReferenceError: arguments is not defined
};
const newFn2 = (...args) => {
console.log(args); // [1, 2, 3]
};
不能作为构造函数,不能用 new 调用
箭头函数没有 [[Construct]] 内部方法,因此不能用 new 实例化,否则会报错 TypeError: xxx is not a constructor。
它也没有 prototype 属性,无法用于实现原型继承。
所以:需要创建实例对象、依赖 this 指向实例、或需原型链的场景,必须用普通函数(包括 function 声明、表达式或 class 方法)。
本篇关于《JavaScript箭头函数是什么?区别详解》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
104 收藏
-
454 收藏
-
477 收藏
-
491 收藏
-
411 收藏
-
361 收藏
-
243 收藏
-
307 收藏
-
186 收藏
-
278 收藏
-
397 收藏
-
344 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习