0

0

javascript ES6的类(class)如何使用?【教程】

夢幻星辰

夢幻星辰

发布时间:2026-02-01 22:29:34

|

573人浏览过

|

来源于php中文网

原创

ES6的class是语法糖,基于原型继承;用class声明、constructor初始化;不提升;需用extends和super()实现继承;私有成员用#前缀;类字段在super()后初始化。

javascript es6的类(class)如何使用?【教程】

ES6 的 class 不是新对象模型,只是语法糖——它背后仍是基于原型的继承,不能替代对 prototype 和构造函数的理解。

如何定义一个基础类?

class 关键字声明,内部用 constructor 定义初始化逻辑。注意:类声明不会被提升(hoisted),必须先声明后使用。

常见错误:ReferenceError: Cannot access 'MyClass' before initialization —— 就是因为把它当成了 function 声明来用了。

  • constructor 是可选的;没写时会默认提供一个空构造函数
  • 类体中只能写方法(含 get/set)、静态方法(static)和字段(public 或 #private),不能写语句或表达式
  • 类名在类内部可通过 constructor.name 获取,但不能直接用类名递归调用自身(比如在 constructor 里写 new MyClass() 会报错,除非类名已存在且在作用域外)

怎么实现继承?extendssuper() 必须一起用

子类构造函数中若定义了 constructor,就必须显式调用 super(),否则会报 ReferenceError: Must call super constructor in derived class before accessing 'this' or returning from derived constructor

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

原因:super() 负责初始化 this,不调就无法访问实例属性。

动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版
动态WEB网站中的PHP和MySQL:直观的QuickPro指南第2版

动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包

下载
  • super() 必须在 this 之前调用,哪怕只调一次
  • super 也可作为对象调用父类方法:super.methodName()
  • 静态方法也能被 extends 继承,但需通过 super 在子类静态方法中调用父类静态方法

私有字段和方法怎么写?用 # 前缀,不是 private 关键字

ES6 没有 private 关键字;真正的私有成员必须以 # 开头,且只能在类内部访问。试图从外部读写 obj.#field 会直接报 SyntaxErrorTypeError

注意:# 字段不可枚举、不可代理、不可反射(Reflect.ownKeys() 不返回它们),也不参与 JSON.stringify()

  • 私有方法也必须用 # 前缀,且只能被同个类内的其他方法调用
  • 不能用字符串拼接绕过:比如 this['#' + 'name'] 无效
  • 私有字段名必须在类定义时就确定,不能动态生成(#[key] 不合法)

类字段(class fields)的陷阱:不在 constructor 里初始化时,顺序很重要

类字段(如 value = 123)会在 constructor 执行前初始化,但它们的执行顺序是自上而下——如果字段依赖尚未声明的变量,就会报 ReferenceError

例如:foo = this.bar(); bar() { return 'ok'; } 是合法的;但 foo = this.baz; baz = 'ok'; 会出错,因为 baz 还未赋值。

  • 字段初始化表达式中可以调用方法,但不能引用尚未声明的字段
  • 字段初始化发生在 super() 之后、constructor 函数体之前
  • 如果同时有 constructor 和字段初始化,建议把复杂逻辑收进 constructor,避免隐式执行顺序问题

真正容易被忽略的是:类不是“类型系统”,TypeScript 的 class 会编译成 ES6 类,但 JavaScript 运行时根本不检查类型;所有 instanceoftypeof、原型链操作,都还是原来那套。别指望 class 自动带来封装或类型安全。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

423

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

537

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

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新特性的相关的文章、下载、课程内容,供大家免费下载体验。

195

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

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

223

2025.12.24

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

361

2023.08.03

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

30

2026.01.31

热门下载

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

精品课程

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

共58课时 | 4.5万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

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

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