javascript中箭头函数是什么_与传统函数有何不同呢
发布时间 - 2026-01-07 00:00:00 点击率:次箭头函数不是语法糖,它与function函数在this绑定、无法new调用、无arguments和yield、单表达式隐式返回等核心行为上存在本质差异,不可随意互换。
箭头函数不是语法糖,它和 function 关键字声明的函数在 this、arguments、new 调用等核心行为上存在本质差异,不能随意互换。
箭头函数没有自己的 this,始终继承外层作用域的 this
这是最常踩坑的一点。传统函数的 this 取决于调用方式(如 obj.fn() 中 this 指向 obj),而箭头函数根本不绑定 this,它只是沿作用域链向上找外层函数的 this 值。
常见错误现象:
- 对象方法写成箭头函数后,
this指向全局或undefined(严格模式) - 事件回调里用箭头函数,本想访问实例属性却报
Cannot read property 'xxx' of undefined
const obj = {
name: 'Alice',
regularFn: function() {
console.log(this.name); // 'Alice'
},
ar
rowFn: () => {
console.log(this.name); // undefined(浏览器中是 window.name,通常为空)
}
};箭头函数不能作为构造函数,也不能使用 new
它没有 [[Construct]] 内部方法,也没有 prototype 属性。一旦尝试 new 一个箭头函数,会直接抛出 TypeError: xxx is not a constructor。
使用场景限制:
- 不能用于定义类或需要实例化的工具函数
- Vue 2 的
data选项若写成箭头函数,会导致this失效,进而data返回空对象 - React 类组件中,生命周期方法、
render等不能用箭头函数定义(否则无法被框架正确调用)
箭头函数没有 arguments,也不支持 yield
它无法通过 arguments 访问实参列表,也不能用作 Generator 函数。替代方案是使用剩余参数 ...args。
参数差异与兼容性影响:
-
function fn() { console.log(arguments[0]); }✅ 可用 -
const fn = () => { console.log(arguments[0]); }❌ 报ReferenceError: arguments is not defined -
const fn = (...args) => console.log(args[0]);✅ 推荐写法 -
const gen = () => { yield 1; }❌ 语法错误:箭头函数不能含yield
箭头函数体为单表达式时可省略 return 和花括号
这是唯一一个纯语法便利点,但要注意隐式返回的边界:
-
x => x * 2→ 隐式返回数值 -
x => { x * 2 }→ 没有return,实际返回undefined -
x => ({ id: x })→ 圆括号包裹对象字面量,避免被解析为代码块
容易忽略的是:一旦加了花括号,就必须显式写 return,否则返回值永远是 undefined —— 这在 map、filter 等高阶函数中极易导致逻辑静默失败。
# vue
# react
# javascript
# java
# 浏览器
# 工具
# win
# 作用域
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
html文件怎么打开证书错误_https协议的html打开提示不安全【指南】
高端云建站费用究竟需要多少预算?
Laravel如何实现多对多模型关联?(Eloquent教程)
Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】
Laravel与Inertia.js怎么结合_使用Laravel和Inertia构建现代单页应用
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
浅析上传头像示例及其注意事项
制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?
Win11怎么恢复误删照片_Win11数据恢复工具使用【推荐】
如何快速生成可下载的建站源码工具?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
Android实现代码画虚线边框背景效果
高端建站如何打造兼具美学与转化的品牌官网?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】
Laravel如何创建自定义中间件?(Middleware代码示例)
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
网站制作免费,什么网站能看正片电影?
Bootstrap CSS布局之列表
北京的网站制作公司有哪些,哪个视频网站最好?
香港服务器如何优化才能显著提升网站加载速度?
如何在IIS7上新建站点并设置安全权限?
PHP正则匹配日期和时间(时间戳转换)的实例代码
Laravel如何生成PDF或Excel文件_Laravel文档导出工具与使用教程
Swift开发中switch语句值绑定模式
佛山企业网站制作公司有哪些,沟通100网上服务官网?
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
Linux系统运维自动化项目教程_Ansible批量管理实战
网页制作模板网站推荐,网页设计海报之类的素材哪里好?
php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】
米侠浏览器网页图片不显示怎么办 米侠图片加载修复
Laravel如何实现用户密码重置功能?(完整流程代码)
Laravel模型关联查询教程_Laravel Eloquent一对多关联写法
Python结构化数据采集_字段抽取解析【教程】
Laravel如何从数据库删除数据_Laravel destroy和delete方法区别
jquery插件bootstrapValidator表单验证详解
如何用免费手机建站系统零基础打造专业网站?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
Laravel如何处理和验证JSON类型的数据库字段
Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程
JavaScript Ajax实现异步通信
zabbix利用python脚本发送报警邮件的方法
重庆市网站制作公司,重庆招聘网站哪个好?
laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法
Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】


rowFn: () => {
console.log(this.name); // undefined(浏览器中是 window.name,通常为空)
}
};