登录
首页 >  文章 >  前端

JavaScript箭头函数是什么?区别详解

时间:2026-02-18 21:11:38 435浏览 收藏

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

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学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>