0

0

javascript ES6类如何定义_它是否彻底改变了继承机制?

夜晨

夜晨

发布时间:2026-01-02 13:27:02

|

568人浏览过

|

来源于php中文网

原创

es6 class 是语法糖,本质仍是原型链继承,所有继承基于[[prototype]]链,class声明编译为构造函数并自动设置prototype和constructor,extends通过object.setprototypeof实现继承。

javascript es6类如何定义_它是否彻底改变了继承机制?

ES6 class 只是语法糖,底层仍是原型链继承

它没有改变 JavaScript 的继承机制本质——所有继承依然基于 [[Prototype]] 链。所谓“类”,只是把原本用 function + prototype + Object.setPrototypeOf 手动搭的结构,包装成更接近传统 OOP 语言的写法。

真正执行时,class 声明会被编译为构造函数,并自动设置 prototypeconstructor 属性;extends 则会调用 Object.setPrototypeOf(SubClass, SuperClass)Object.setPrototypeOf(SubClass.prototype, SuperClass.prototype)

  • class 内部方法默认不可枚举(比手写 prototype 更干净)
  • class 声明不会被提升(而函数声明会),且必须用 new 调用,否则报 TypeError: Class constructor X cannot be invoked without 'new'
  • 静态方法和实例方法都通过 prototype 或构造函数本身挂载,没新增任何底层机制

如何正确定义 class 并实现继承?

关键在三步:定义基类、用 extends 继承、子类中必须调用 super()(哪怕不传参)。

class Animal {
  constructor(name) {
    this.name = name;
  }
  speak() {
    return `${this.name} makes a sound.`;
  }
}

class Dog extends Animal {
  constructor(name, breed) {
    super(name); // ← 必须!否则报 ReferenceError
    this.breed = breed;
  }
  speak() {
    return `${this.name} barks.`;
  }
}
  • 不写 constructor 时,子类会自动获得默认构造函数:constructor(...args) { super(...args); }
  • super() 必须在访问 this 之前调用,否则报 ReferenceError: Must call super constructor in derived class before accessing 'this' or returning from derived constructor
  • 静态方法也能被继承:Dog.isAnimal = true 不会覆盖从 Animal 继承来的 isAnimal,但可通过 static get isAnimal() { return true; } 显式定义

为什么 instanceofObject.getPrototypeOf 仍能准确反映真实关系?

因为 class 没有绕过原型系统,只是让原型链更“规整”。你可以用原生 API 验证它的底层结构:

VisualizeAI
VisualizeAI

用AI把你的想法变成现实

下载

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

const dog = new Dog('Max', 'Golden');
console.log(dog instanceof Dog); // true
console.log(dog instanceof Animal); // true
console.log(Object.getPrototypeOf(dog) === Dog.prototype); // true
console.log(Object.getPrototypeOf(Dog.prototype) === Animal.prototype); // true
  • Dog.prototype.__proto__ 指向 Animal.prototype(尽管不推荐直接用 __proto__
  • Dog.__proto__ 指向 Animal,这决定了静态属性/方法的继承链
  • 如果你手动修改 Dog.prototype(比如赋值为新对象),会断开与 Animal.prototype 的连接,instanceof 就会失效

容易被忽略的细节:私有字段、new.target 和装饰器兼容性

ES6 class 本身不支持私有成员,直到 ES2022 才加入 #field 语法;而 new.targetclass 构造器中行为更严格——它能区分是否被 new 调用,这对编写可继承的工具类很关键。

  • 私有字段 #name 是真正的私有(无法被子类访问),不是命名约定(如 _name
  • new.target 在基类构造器中指向实际被 new 的类(比如 new Dog() 时,new.target === Dog),可用于防止类被直接实例化
  • 目前主流装饰器提案(如 @bound)依赖 Babel 或 TypeScript 转译,原生 class 不支持运行时装饰,这点常被误认为是“类的限制”

真正复杂的地方在于:你得同时理解语法糖表象和原型链实质。一旦遇到奇怪的 instanceof 失败、this 绑定异常或继承链断裂,问题几乎总出在原型操作被意外覆盖,而不是 class 本身。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

43

2026.02.13

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

114

2026.02.25

es6新特性
es6新特性

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

106

2023.07.17

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

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

196

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

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

231

2025.12.24

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

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

747

2024.01.03

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

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

23

2025.12.06

function是什么
function是什么

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

495

2023.08.04

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

43

2026.02.28

热门下载

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

精品课程

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

共58课时 | 5.6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.2万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

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

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