什么是javascript的箭头函数_为什么箭头函数没有自己的this绑定
发布时间 - 2025-12-25 00:00:00 点击率:次箭头函数不绑定自身this,而是继承外层作用域的this值;它用=>定义,无arguments、prototype、super和new.target,不能作为构造函数。
箭头函数是 JavaScript 中一种简洁的函数定义语法,它不绑定自己的 this,而是继承外层作用域的 this 值。这是它和传统函数最核心的区别之一。
箭头函数的基本写法和特点
箭头函数用 => 定义,省略 function 关键字,参数少时可省括号,单表达式可省大括号和 return:
const add = (a, b) => a + b;const sayHi = () => console.log('Hi');const obj = { name: 'Alice', getName: ()
=> this.name }; // this 指向外层,不是 obj
为什么箭头函数没有自己的 this
因为箭头函数在词法上“捕获”外层执行上下文的 this,而不是在调用时动态绑定。它没有自己的执行上下文(没有自己的 [[ThisBinding]]),所以不参与 this 的常规绑定规则(如默认绑定、隐式绑定、显式绑定、new 绑定)。
- 普通函数的
this取决于**怎么被调用**(例如obj.method()中this是obj) - 箭头函数的
this取决于**它在哪儿被定义**(即外层函数或全局作用域的this) - 因此
call、apply、bind对箭头函数的this无效
常见陷阱与适用场景
误用箭头函数容易导致 this 意外丢失,尤其在对象方法或事件回调中:
- ❌ 错误:对象方法写成箭头函数 →
this不指向该对象 - ✅ 正确:需要动态
this时用普通函数;需要稳定继承外层this时用箭头函数(如 React 类组件中事件处理、定时器回调、Promise 链内) - ✅ 典型安全用法:
setTimeout(() => console.log(this.value), 100);—— 避免手动bind(this)
补充说明:箭头函数的其他限制
除了没有 this,箭头函数也没有:
-
arguments对象(可用剩余参数...args替代) -
prototype属性(不能用作构造函数,调用new会报错) -
super和new.target(在类中不可用)
# react
# javascript
# java
# app
# 区别
# 作用域
# 为什么
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
简单实现jsp分页
Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程
如何用西部建站助手快速创建专业网站?
如何撰写建站申请书?关键要点有哪些?
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
如何快速使用云服务器搭建个人网站?
PythonWeb开发入门教程_Flask快速构建Web应用
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
如何在万网自助建站平台快速创建网站?
黑客如何通过漏洞一步步攻陷网站服务器?
如何在 Pandas 中基于一列条件计算另一列的分组均值
微信小程序 闭包写法详细介绍
Laravel如何使用Blade模板引擎?(完整语法和示例)
如何用y主机助手快速搭建网站?
打开php文件提示内存不足_怎么调整php内存限制【解决方案】
Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程
Laravel如何发送系统通知?(Notification渠道示例)
如何快速选择适合个人网站的云服务器配置?
Laravel Asset编译怎么配置_Laravel Vite前端构建工具使用
如何用JavaScript实现文本编辑器_光标和选区怎么处理
怎么用AI帮你为初创公司进行市场定位分析?
如何在IIS7上新建站点并设置安全权限?
详解Android——蓝牙技术 带你实现终端间数据传输
Laravel distinct去重查询_Laravel Eloquent去重方法
哪家制作企业网站好,开办像阿里巴巴那样的网络公司和网站要怎么做?
js实现获取鼠标当前的位置
悟空浏览器如何设置小说背景色_悟空浏览器背景色设置【方法】
如何快速生成橙子建站落地页链接?
如何将凡科建站内容保存为本地文件?
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
javascript中的try catch异常捕获机制用法分析
Laravel怎么实现微信登录_Laravel Socialite第三方登录集成
新三国志曹操传主线渭水交兵攻略
高防服务器如何保障网站安全无虞?
Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率
edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】
Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比
独立制作一个网站多少钱,建立网站需要花多少钱?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
公司门户网站制作流程,华为官网怎么做?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
如何在七牛云存储上搭建网站并设置自定义域名?
微信小程序 HTTPS报错整理常见问题及解决方案
JavaScript中如何操作剪贴板_ClipboardAPI怎么用
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析


=> this.name }; // this 指向外层,不是 obj