0

0

JS类和继承怎么实现_JS ES6类class与继承机制使用教程

絕刀狂花

絕刀狂花

发布时间:2025-11-09 16:01:02

|

654人浏览过

|

来源于php中文网

原创

答案:ES6的class语法基于原型机制,提供更清晰的面向对象编程方式,包括构造函数、继承、静态成员和getter/setter。1. 使用class定义类,constructor初始化属性,方法定义在原型上;2. 通过extends实现继承,子类需调用super()初始化父类;3. static定义静态方法或属性,属于类本身而非实例;4. getter/setter用于控制属性访问与赋值,常用于数据校验。

js类和继承怎么实现_js es6类class与继承机制使用教程

ES6 引入了 class 语法,让 JavaScript 的面向对象编程更接近传统语言(如 Java、C++),但其底层依然是基于原型(prototype)的机制。类和继承的实现更加清晰、易读。

1. JS 中 class 的基本用法

使用 class 关键字可以定义一个类。类中通过 constructor 定义构造函数,用于初始化实例属性。

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

  sayHello() {
    console.log(`你好,我是${this.name}`);
  }
}

const p1 = new Person("小明", 25);
p1.sayHello(); // 输出:你好,我是小明

说明:

  • constructor 是构造方法,创建实例时自动调用
  • 方法之间不需要逗号分隔,也不是键值对形式
  • 所有方法都定义在类的原型上(prototype)

2. 类的继承:extends 和 super

使用 extends 实现类的继承,子类可以继承父类的属性和方法。在子类的 constructor 中必须调用 super(),否则无法使用 this。

class Student extends Person {
  constructor(name, age, grade) {
    super(name, age); // 调用父类构造函数
    this.grade = grade;
  }

  study() {
    console.log(`${this.name} 正在学习`);
  }

  // 可以重写父类方法
  sayHello() {
    console.log(`学生说:我是${this.name},今年${this.age}岁`);
  }
}

const s1 = new Student("小红", 20, "大三");
s1.sayHello(); // 学生说:我是小红,今年20岁
s1.study();     // 小红 正在学习

关键点:

  • extends 表示继承自某个类
  • super() 必须在子类 constructor 中调用,用来初始化父类的 this
  • super 也可以调用父类的其他方法,如 super.sayHello()

3. 静态方法与静态属性

使用 static 关键字定义静态方法或属性,它们属于类本身,而不是实例。

Img.Upscaler
Img.Upscaler

免费的AI图片放大工具

下载
class MathUtils {
  static PI = 3.14159;

  static add(a, b) {
    return a + b;
  }
}

console.log(MathUtils.add(2, 3)); // 5
console.log(MathUtils.PI);        // 3.14159

// 注意:不能通过实例调用静态方法
const mu = new MathUtils();
// mu.add(2, 3); // 错误:mu.add is not a function

静态方法常用于工具类或不需要实例化的功能。

4. getter 和 setter

可以在类中定义 getter 和 setter,用于控制属性的访问和赋值。

class BankAccount {
  constructor(balance) {
    this._balance = balance; // 私有化约定
  }

  get balance() {
    return this._balance + " 元";
  }

  set balance(amount) {
    if (amount < 0) {
      console.log("余额不能为负!");
      return;
    }
    this._balance = amount;
  }
}

const account = new BankAccount(100);
console.log(account.balance); // 100 元
account.balance = -50;        // 余额不能为负!
account.balance = 200;
console.log(account.balance); // 200 元

get 和 set 让你可以拦截属性的读写操作,增强数据安全性。

基本上就这些。class 让代码结构更清晰,继承更直观,是现代 JS 开发的推荐方式。虽然底层仍是原型链,但语法糖大大提升了开发体验。不复杂但容易忽略细节,比如 super 的调用时机和静态成员的访问方式。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

651

2023.06.15

java流程控制语句有哪些
java流程控制语句有哪些

java流程控制语句:1、if语句;2、if-else语句;3、switch语句;4、while循环;5、do-while循环;6、for循环;7、foreach循环;8、break语句;9、continue语句;10、return语句。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

454

2024.02.23

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

722

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

725

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

394

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

441

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

427

2023.08.02

笔记本电脑卡反应很慢处理方法汇总
笔记本电脑卡反应很慢处理方法汇总

本专题整合了笔记本电脑卡反应慢解决方法,阅读专题下面的文章了解更多详细内容。

1

2025.12.25

热门下载

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

精品课程

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

共61课时 | 3.1万人学习

HTML教程
HTML教程

共500课时 | 4.2万人学习

手把手实现数据传输编码
手把手实现数据传输编码

共1课时 | 700人学习

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

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