0

0

理解 JavaScript 中的类和继承

霞舞

霞舞

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

|

956人浏览过

|

来源于php中文网

原创

理解 javascript 中的类和继承

JavaScript 类与继承详解

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


1. JavaScript 类

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

类定义语法:

class 类名 {
  构造函数() {
    // 初始化代码
  }
  方法名() {
    // 方法代码
  }
}

基本类示例:

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

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

关键点:

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

2. JavaScript 继承

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

继承语法:

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

继承示例:

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,一只金毛寻回犬,汪汪叫。

关键点:

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

3. 方法重写

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

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

方法重写示例:

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 喵喵叫。

关键点:

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

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

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

贞龙网店商城电子商务系统java版
贞龙网店商城电子商务系统java版

BIZOSS-B2C是脱胎于贞龙B2B大型平台的网上商城系统、网上商店系统、网上购物系统的企业级B2C电子商务解决方案。系统设置:这里包含了网店的常用功能和全局配置的开关。包括 商店设置 、支付方式和配送方式 、邮件服务器设置、地区列表、友情链接、自定义导航栏、站点地图。商品管理:网店展示商品的核心。其中包括了 商品分类、商品类型、商品品牌、商品回收站、商品上下架等一些设置。促销管理:这个是我们网

下载

Mixin 示例:

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(); // 输出:麻雀 正在飞翔。

关键点:

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

5. 静态方法和属性

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

静态方法示例:

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

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

关键点:

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

6. Getter 和 Setter

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

Getter 和 Setter 示例:

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

关键点:

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

7. 总结

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

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

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

195

2023.08.04

JavaScript ES6新特性
JavaScript ES6新特性

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

222

2025.12.24

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

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

56

2025.09.05

java面向对象
java面向对象

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

52

2025.11.27

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

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

15

2025.11.27

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

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

15

2025.11.27

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

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

15

2025.11.27

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

11

2026.01.29

热门下载

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

精品课程

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

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