0

0

javascript箭头函数是什么_它与普通函数有什么区别?

狼影

狼影

发布时间:2025-12-27 17:55:02

|

327人浏览过

|

来源于php中文网

原创

箭头函数是ES6引入的简洁函数语法,无this/arguments/super/new.target,不能作构造函数,适合简短回调但不适用需动态this或实例化的场景。

javascript箭头函数是什么_它与普通函数有什么区别?

箭头函数是 ES6 引入的一种简洁的函数定义语法,它没有自己的 thisargumentssupernew.target,行为更轻量,也更适用于某些场景。

语法更简洁

箭头函数省略了 function 关键字和 return(单表达式时自动返回),写起来更紧凑:

  • 普通函数:const add = function(a, b) { return a + b; };
  • 箭头函数:const add = (a, b) => a + b;
  • 单参数可省括号:const square = x => x * x;
  • 无参需写空括号:const sayHi = () => "Hello";

this 绑定方式不同

普通函数的 this 取决于调用方式(谁调用,this 就是谁);箭头函数没有自己的 this,它会沿作用域链向上找外层最近的非箭头函数的 this 值,且无法通过 callapplybind 改变。

  • 这意味着在对象方法或事件回调中,用箭头函数容易“意外”保留定义时的 this,比如定时器里访问对象属性时可能出错。
  • 如果需要动态 this(如 Vue 方法、React 类组件事件处理),通常得用普通函数。

不能作为构造函数

箭头函数没有 prototype,也没有 [[Construct]] 内部方法,所以不能用 new 调用,否则会报错。

AVCLabs
AVCLabs

AI移除视频背景,100%自动和免费

下载

立即学习Java免费学习笔记(深入)”;

  • new (() => {}) // TypeError: is not a constructor
  • 需要实例化对象时,必须使用普通函数或 class。

没有 arguments 对象

箭头函数内部访问 arguments 会报错或取到外层函数的 arguments(如果存在)。替代方案是使用剩余参数 ...args

  • 普通函数:function sum() { return Array.from(arguments).reduce((a, b) => a + b); }
  • 箭头函数:const sum = (...args) => args.reduce((a, b) => a + b);

基本上就这些。箭头函数不是万能替代品,而是补充工具——适合简短逻辑、避免 this 混乱的回调,但不适合需要动态上下文或构造能力的场景。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
es6新特性
es6新特性

es6新特性有:1、块级作用域变量;2、箭头函数;3、模板字符串;4、解构赋值;5、默认参数;6、 扩展运算符;7、 类和继承;8、Promise。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

103

2023.07.17

es6新特性有哪些
es6新特性有哪些

es6的新特性有:1、块级作用域;2、箭头函数;3、解构赋值;4、默认参数;5、扩展运算符;6、模板字符串;7、类和模块;8、迭代器和生成器;9、Promise对象;10、模块化导入和导出等等。本专题为大家提供es6新特性的相关的文章、下载、课程内容,供大家免费下载体验。

195

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

221

2025.12.24

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

530

2023.09.20

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

469

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

13

2025.12.06

function是什么
function是什么

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果。本专题为大家提供function是什么的相关的文章、下载、课程内容,供大家免费下载体验。

482

2023.08.04

js函数function用法
js函数function用法

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。本专题提供js函数function用法的相关文章内容,大家可以免费阅读。

163

2023.10.07

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Vue 教程
Vue 教程

共42课时 | 7.3万人学习

Vue3.x 工具篇--十天技能课堂
Vue3.x 工具篇--十天技能课堂

共26课时 | 1.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号