首页 > web前端 > js教程 > 正文

JavaScript中的类(Class)与继承_javascript ES6

夢幻星辰
发布: 2025-10-29 21:51:02
原创
230人浏览过
JavaScript中的类是ES6语法糖,基于原型机制提供更清晰的面向对象编程方式。1. 使用class定义类,包含constructor初始化属性和实例方法;2. 通过extends实现继承,子类需调用super()初始化父类;3. 子类可重写父类方法并用super调用原方法;4. static定义静态方法,属类本身不可被实例调用。该语法提升代码可读性与结构清晰度。

javascript中的类(class)与继承_javascript es6

JavaScript 中的类(Class)是 ES6 引入的一种语法糖,让开发者可以用更接近传统面向对象语言的方式来创建对象和实现继承。虽然 JavaScript 基于原型(prototype)的机制没有改变,但 class 的写法更加清晰、易读。

类的基本语法

使用 class 关键字可以定义一个类。类中通常包含一个 constructor 方法,用于初始化实例属性,还可以定义其他方法。

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

  greet() {
    console.log(`Hello, I'm ${this.name}`);
  }
}

const person1 = new Person("Alice", 25);
person1.greet(); // 输出: Hello, I'm Alice
登录后复制

上面的例子中,Person 是一个类,通过 new 创建实例。constructor 构造函数在实例化时自动调用。

类的继承(extends)

ES6 提供了 extends 关键字来实现类的继承,子类可以继承父类的属性和方法。

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

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

  study() {
    console.log(`${this.name} is studying.`);
  }
}

const student1 = new Student("Bob", 20, "A");
student1.greet(); // 继承自 Person:Hello, I'm Bob
student1.study(); // Student 自有方法:Bob is studying.
登录后复制

子类必须在 constructor 中调用 super(),否则无法使用 this。super 指向父类的构造函数或原型方法。

百度文心百中
百度文心百中

百度大模型语义搜索体验中心

百度文心百中22
查看详情 百度文心百中

方法重写与 super 调用

子类可以重写父类的方法。如果想在重写的同时调用父类的方法,可以用 super.方法名()

class Teacher extends Person {
  constructor(name, age, subject) {
    super(name, age);
    this.subject = subject;
  }

  greet() {
    super.greet(); // 调用父类的 greet
    console.log(`I teach ${this.subject}.`);
  }
}

const teacher1 = new Teacher("Charlie", 35, "Math");
teacher1.greet();
// 输出:
// Hello, I'm Charlie
// I teach Math.
登录后复制

静态方法

使用 static 关键字定义静态方法,属于类本身,不能通过实例调用。

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

console.log(MathUtils.add(2, 3)); // 5
// const utils = new MathUtils();
// utils.add(2, 3); // 错误:add 不是实例方法
登录后复制

基本上就这些。class 让 JavaScript 的面向对象编程更直观,但底层依然是原型链。掌握 class 和 extends,能让你写出结构更清晰、易于维护的代码。

以上就是JavaScript中的类(Class)与继承_javascript ES6的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

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