0

0

理解 JavaScript 中的类和继承

霞舞

霞舞

发布时间:2024-12-18 17:21:01

|

956人浏览过

|

来源于php中文网

原创

理解 javascript 中的类和继承

JavaScript 类与继承详解

JavaScript 类为面向对象编程 (OOP) 提供了现代化的语法支持,涵盖继承、封装和多态等核心概念。本文将深入探讨 JavaScript 类和继承的创建、使用方法以及高级应用。


1. JavaScript 类

ES6 引入了 class 关键字,使类的定义更加清晰简洁。

类定义语法:

<code class="javascript">class 类名 {
  构造函数() {
    // 初始化代码
  }
  方法名() {
    // 方法代码
  }
}</code>

基本类示例:

<code class="javascript">class Animal {
  constructor(name, type) {
    this.name = name;
    this.type = type;
  }
  speak() {
    console.log(`${this.name} 发出声音。`);
  }
}

const dog = new Animal('Buddy', '狗');
dog.speak(); // 输出:Buddy 发出声音。</code>

关键点:

  • 构造函数 (constructor): 用于初始化类的实例。
  • 实例方法: 类中定义的方法,可在实例上调用。

2. JavaScript 继承

继承允许一个类继承另一个类的属性和方法,使用 extends 关键字实现。

继承语法:

<code class="javascript">class 子类 extends 父类 {
  constructor() {
    super(); // 调用父类构造函数
    // 子类额外初始化代码
  }
}</code>

继承示例:

<code class="javascript">class Animal {
  constructor(name) {
    this.name = name;
  }
  speak() {
    console.log(`${this.name} 发出声音。`);
  }
}

class Dog extends Animal {
  constructor(name, breed) {
    super(name); // 调用父类构造函数
    this.breed = breed;
  }
  speak() {
    console.log(`${this.name},一只${this.breed},汪汪叫。`);
  }
}

const dog = new Dog('Buddy', '金毛寻回犬');
dog.speak(); // 输出:Buddy,一只金毛寻回犬,汪汪叫。</code>

关键点:

  • super(): 调用父类构造函数。
  • 方法重写: 子类可以重写父类的方法。

3. 方法重写

子类可以重写父类的方法,使用子类版本的实现。

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

方法重写示例:

<code class="javascript">class Animal {
  constructor(name) {
    this.name = name;
  }
  speak() {
    console.log(`${this.name} 发出声音。`);
  }
}

class Cat extends Animal {
  speak() {
    console.log(`${this.name} 喵喵叫。`);
  }
}

const cat = new Cat('Whiskers');
cat.speak(); // 输出:Whiskers 喵喵叫。</code>

关键点:

  • 子类方法实现会覆盖父类方法。
  • 可使用 super.方法名() 调用父类方法。

4. 多重继承(间接实现)

JavaScript 不直接支持多重继承,但可以使用 Mixin 模式来模拟。

Tago AI
Tago AI

AI生成带货视频,专为电商卖货而生

下载

Mixin 示例:

<code class="javascript">const FlyMixin = {
  fly() {
    console.log(`${this.name} 正在飞翔。`);
  }
};

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

Object.assign(Bird.prototype, FlyMixin);

const bird = new Bird('麻雀');
bird.fly(); // 输出:麻雀 正在飞翔。</code>

关键点:

  • Mixin 通过将方法混合到原型链上实现功能扩展。
  • Object.assign() 用于将 Mixin 的方法添加到类原型。

5. 静态方法和属性

静态方法和属性属于类本身,而非实例。

静态方法示例:

<code class="javascript">class MathUtil {
  static add(a, b) {
    return a + b;
  }
}

console.log(MathUtil.add(5, 3)); // 输出:8</code>

关键点:

  • 静态方法用于无需实例上下文的操作。

6. Getter 和 Setter

Getter 和 Setter 用于控制属性的访问和修改。

Getter 和 Setter 示例:

<code class="javascript">class Person {
  constructor(name) {
    this._name = name;
  }

  get name() {
    return this._name;
  }

  set name(newName) {
    this._name = newName;
  }
}

const person = new Person('Alice');
console.log(person.name); // 输出:Alice
person.name = 'Bob';
console.log(person.name); // 输出:Bob</code>

关键点:

  • Getter 用于获取属性值。
  • Setter 用于设置属性值。

7. 总结

JavaScript 类和继承是构建复杂应用的关键。理解这些概念能编写更清晰、更易维护的代码。 类提供了一种创建对象并管理其行为的现代方法,继承则允许代码复用和扩展。 Mixin 和静态方法等特性进一步增强了 JavaScript 的面向对象编程能力。

作者:Abhay Singh Kathayat (联系方式略)

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

197

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

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

233

2025.12.24

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

java面向对象
java面向对象

本专题整合了java面向对象相关内容,阅读专题下面的文章了解更多详细内容。

63

2025.11.27

java多态详细介绍
java多态详细介绍

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

27

2025.11.27

java多态详细介绍
java多态详细介绍

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

27

2025.11.27

java多态详细介绍
java多态详细介绍

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

27

2025.11.27

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

热门下载

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

精品课程

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

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