0

0

javascript的箭头函数有何特点_它为什么不能用作构造函数【教程】

夜晨

夜晨

发布时间:2026-01-17 21:03:51

|

458人浏览过

|

来源于php中文网

原创

箭头函数不可用作构造函数,因其无prototype属性、无[[construct]]内部方法、this词法绑定且无arguments和new.target;普通函数或class才支持new调用。

javascript的箭头函数有何特点_它为什么不能用作构造函数【教程】

箭头函数没有 prototype 属性

普通函数声明或表达式创建的函数对象,自带 prototype 属性,这是 JavaScript 实现原型继承和 new 操作的基础。而箭头函数被设计为“语法糖”,不绑定自己的 prototype——它根本就没有这个属性。

你可以直接在控制台验证:

function Normal() {}
console.log(Normal.prototype); // { constructor: Normal }

const Arrow = () => {};
console.log(Arrow.prototype); // undefined

当执行 new Arrow() 时,引擎会尝试读取 Arrow.prototype 来设置新对象的 [[Prototype]],但该属性不存在,于是抛出 TypeError: Arrow is not a constructor

箭头函数没有 this 绑定能力,更无 [[Construct]] 内部方法

构造函数必须具备 [[Construct]] 内部方法,才能响应 new 调用。只有具有该方法的对象(如普通函数、类、内置构造器)才可被 new 调用。箭头函数被明确规范为“不可构造”(not constructable),其内部不实现 [[Construct]]

Kacha
Kacha

KaCha是一款革命性的AI写真工具,用AI技术将照片变成杰作!

下载

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

  • this 在箭头函数中是词法绑定的,无法通过 new 改变上下文
  • 没有 arguments 对象,也没有 new.targetnew.target 在箭头函数体内始终为 undefined
  • 不能用 call/apply/bind 改变 this,自然也无法模拟构造行为

哪些场景下误用箭头函数会导致构造错误

常见于试图替代类或工厂函数的写法,尤其在团队协作或代码重构时容易踩坑:

  • 把类方法写成箭头函数后,又想用 new 实例化该方法(实际应定义在 class 中)
  • 用箭头函数封装初始化逻辑,比如 const createPerson = (name) => ({ name });,误以为可以 new createPerson('Alice')
  • 在 Vue 2 的 data 选项中返回箭头函数(虽不报错,但破坏响应式原理;Vue 3 的 setup 中若误用箭头函数定义响应式工厂,也会导致无法正确追踪)

替代方案:什么时候该用普通函数或 class

需要实例化、有原型链、需访问 new.target 或自定义 this 行为时,必须用普通函数或 class

class Person {
  constructor(name) {
    this.name = name;
  }
}

// ✅ 正确
const p = new Person('Bob');

// ❌ 错误(语法合法但运行时报错)
const BadPerson = (name) => ({ name });
const p2 = new BadPerson('Alice'); // TypeError

如果只是封装逻辑并返回对象,保持箭头函数即可,但别加 new——它本就不是为构造设计的。真正容易忽略的是:即使你没显式写 new,某些框架(如旧版 MobX、部分 DSL 解析器)内部可能尝试调用 [[Construct]],这时箭头函数会静默失败或抛异常。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言const用法
c语言const用法

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

562

2023.09.20

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

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

870

2024.01.03

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

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

30

2025.12.06

undefined是什么
undefined是什么

undefined是代表一个值或变量不存在或未定义的状态。它可以作为默认值来判断一个变量是否已经被赋值,也可以用于设置默认参数值。尽管在不同的编程语言中,undefined可能具有不同的含义和用法,但理解undefined的概念可以帮助我们更好地理解和编写程序。本专题为大家提供undefined相关的各种文章、以及下载和课程。

6469

2023.07.31

网页undefined是什么意思
网页undefined是什么意思

网页undefined是指页面出现了未知错误的意思,提示undefined一般是在开发网站的时候定义不正确或是转换不正确,或是找不到定义才会提示undefined未定义这个错误。想了解更多的相关内容,可以阅读本专题下面的文章。

3336

2024.08.14

网页undefined啥意思
网页undefined啥意思

本专题整合了undefined相关内容,阅读下面的文章了解更多详细内容。后续继续更新。

1670

2025.12.25

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

48

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

93

2026.03.06

热门下载

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

精品课程

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

共42课时 | 9.5万人学习

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

共26课时 | 1.6万人学习

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

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