」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 提升你的 JavaScript:深入研究物件導向程式設計✨

提升你的 JavaScript:深入研究物件導向程式設計✨

發佈於2024-11-07
瀏覽:396

Elevate Your JavaScript: A Deep Dive into Object-Oriented Programming✨

面向对象编程 (OOP) 是一种强大的范例,它彻底改变了我们构建和组织代码的方式。

虽然 JavaScript 最初是一种基于原型的语言,但它已经发展到接受 OOP 原则,特别是随着 ES6 的引入和后续更新。

这篇文章深入研究了 JavaScript 中 OOP 的核心概念,探索如何实现它们来创建更健壮、可维护和可扩展的应用程序。

我们将了解 OOP 的四大支柱 - 继承、抽象、封装和多态性 - 演示如何在 JavaScript 中应用每个原则。在此过程中,我们将研究现实世界的示例并讨论每个概念的优缺点。

无论您是希望提高 JavaScript 中 OOP 技能的经验丰富的开发人员,还是渴望掌握这些基本概念的新手,本指南都将为您在 JavaScript 项目中利用 OOP 的力量提供宝贵的见解。


1。遗产:

继承允许一个类从另一个类继承属性和方法。它提高了代码的可重用性并建立了父类和子类之间的关系。

class Vehicle {
  constructor(make, model) {
    this.make = make;
    this.model = model;
  }

  getInfo() {
    return `${this.make} ${this.model}`;
  }

  start() {
    return "The vehicle is starting...";
  }
}

class Car extends Vehicle {
  constructor(make, model, doors) {
    super(make, model);
    this.doors = doors;
  }

  getCarInfo() {
    return `${this.getInfo()} with ${this.doors} doors`;
  }
}

const myCar = new Car("Toyota", "Corolla", 4);
console.log(myCar.getCarInfo()); // Output: Toyota Corolla with 4 doors
console.log(myCar.start()); // Output: The vehicle is starting...

在此示例中,Car 继承自 Vehicle,获取对其属性和方法的访问权限。

优点:

  • 代码可重用性:子类继承父类的属性和方法。

  • 在对象之间建立清晰的层次结构。

  • 允许方法重写和扩展。

缺点:

  • 可能导致父类和子类之间的紧密耦合。

  • 深层继承层次结构可能会变得复杂且难以维护。


2.抽象

抽象涉及隐藏复杂的实现细节并仅显示对象的必要特征。在 JavaScript 中,我们可以使用抽象类(尽管本身不支持)和接口来实现抽象。

class Shape {
  constructor() {
    if (new.target === Shape) {
      throw new TypeError("Cannot instantiate abstract class");
    }
  }

  calculateArea() {
    throw new Error("Method 'calculateArea()' must be implemented.");
  }
}

class Circle extends Shape {
  constructor(radius) {
    super();
    this.radius = radius;
  }

  calculateArea() {
    return Math.PI * this.radius ** 2;
  }
}

class Rectangle extends Shape {
  constructor(width, height) {
    super();
    this.width = width;
    this.height = height;
  }

  calculateArea() {
    return this.width * this.height;
  }
}

// const shape = new Shape(); // Throws TypeError
const circle = new Circle(5);
const rectangle = new Rectangle(4, 6);

console.log(circle.calculateArea()); // Output: 78.53981633974483
console.log(rectangle.calculateArea()); // Output: 24

在此示例中,Shape 充当无法直接实例化的抽象类。它定义了所有子类都必须实现的公共接口calculateArea。这种抽象允许我们通过通用接口处理不同的形状,而不必担心它们的具体实现。

优点:

  • 通过隐藏不必要的细节来简化复杂的系统。

  • 提高代码可维护性并减少重复。

  • 允许关注对象做什么而不是它如何做。

缺点:

  • 如果设计不仔细,可能会导致过度简化。

  • 在某些情况下可能会带来性能开销。


3.封装

封装是将数据和在单个单元(对象)内操作该数据的方法捆绑在一起。在 JavaScript 中,我们可以使用闭包和符号来创建私有属性和方法。

class BankAccount {
  #balance = 0;  // Private field

  constructor(owner) {
    this.owner = owner;
  }

  deposit(amount) {
    if (amount > 0) {
      this.#balance  = amount;
      return true;
    }
    return false;
  }

  withdraw(amount) {
    if (amount > 0 && this.#balance >= amount) {
      this.#balance -= amount;
      return true;
    }
    return false;
  }

  getBalance() {
    return this.#balance;
  }
}

const account = new BankAccount('John Doe');
account.deposit(1000);
console.log(account.getBalance()); // Output: 1000
console.log(account.#balance); // SyntaxError: Private field '#balance' must be declared in an enclosing class

在此示例中,#balance 是私有字段,无法从类外部直接访问。

优点:

  • 数据保护:防止未经授权访问内部数据。

  • 模块化:将相关功能捆绑在一起。

  • 更容易维护:内部实现的更改不会影响外部代码。

缺点:

  • 由于缺乏真正的私有成员,在 JavaScript 中实现起来可能很复杂。

  • 创建 getter 和 setter 时可能会导致冗长的代码。


4。多态性

多态性允许将不同类的对象视为公共超类的对象。在 JavaScript 中,这可以通过方法重写来实现。

class Animal {
  speak() {
    return "The animal makes a sound";
  }
}

class Dog extends Animal {
  speak() {
    return "The dog barks";
  }
}

class Cat extends Animal {
  speak() {
    return "The cat meows";
  }
}

const animals = [new Animal(), new Dog(), new Cat()];

animals.forEach(animal => {
  console.log(animal.speak());
});

// Output:
// The animal makes a sound
// The dog barks
// The cat meows

在这个例子中,每个类以不同的方式实现speak方法,展示了多态性。

优点:

  • 灵活性:不同类型的对象可以统一处理。

  • 可扩展性:可以在不更改现有代码的情况下添加新类。

  • 通过允许对不同类型使用单一接口来简化代码。

缺点:

  • 如果过度使用,会使代码更难调试。

  • 在某些语言中可能会导致性能开销(在 JavaScript 中较少)。


正如我们所探索的,JavaScript 中的面向对象编程提供了一个强大的工具包,用于创建结构化、可维护和可扩展的代码。 OOP 的四大支柱 - 继承、抽象、封装和多态性 - 每一个都带来独特的优势,允许开发人员建模复杂的系统、保护数据完整性、促进代码重用以及创建灵活、可扩展的应用程序。

虽然由于语言的独特特性,在 JavaScript 中实现这些原则有时可能需要创造性的方法,但好处是显而易见的。 OOP 可以使代码库更有组织性、团队成员之间的协作更轻松,并提高对不断变化的需求的适应性。

然而,重要的是要记住 OOP 并不是一种万能的解决方案。每个项目可能需要对这些原则进行不同的平衡,并且在某些情况下,其他范例可能更合适。关键是要彻底理解这些概念并明智地应用它们,始终牢记您的项目和团队的具体需求。

快乐编码?

版本聲明 本文轉載於:https://dev.to/alaa-samy/elevate-your-javascript-a-deep-dive-into-object-oriented-programming-2080?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 嬰兒學步學習 Laravel
    嬰兒學步學習 Laravel
    歡迎回來,開發者! ✨ 在Laravel 之旅的這一章中(請記住,我在撰寫這些文章時正在學習,因此這將是您能找到的最現實的教程系列之一!),我們將深入研究我們的Laravel 專案。我們將探索專案結構,熟悉遷移,並以最簡單的方式分解 MVC 架構。 ?今天的議程:...
    程式設計 發佈於2024-11-08
  • 如何動態包含具有不受控制的「document.write()」內容的腳本?
    如何動態包含具有不受控制的「document.write()」內容的腳本?
    動態新增具有不受控制的來源內容的腳本標記當內容來自於控制項外部時,建立具有外部來源的腳本標記可能會帶來挑戰包括使用document.write() 的程式碼。如前所述,僅在 中附加 script 標記無法支援此類內容。 要解決此問題,請考慮以下解決方案:使用 document.create 新建一...
    程式設計 發佈於2024-11-08
  • 在 JavaScript 中如何有效地確定一個數字是否為素數?
    在 JavaScript 中如何有效地確定一個數字是否為素數?
    在 JavaScript 中高效驗證素數在電腦程式設計中,決定給定數字是否是質數是一項基本任務。質數是大於 1 的正整數,除了 1 和它本身之外沒有正因數。 檢查素數的一種流行方法涉及埃拉托斯特尼篩法。然而,出於效能考慮,可以採用更有效的方法,如以下 JavaScript 實作所示:let inpu...
    程式設計 發佈於2024-11-08
  • 為什麼 Lambda 表達式需要最終局部變數而不是實例變數?
    為什麼 Lambda 表達式需要最終局部變數而不是實例變數?
    Lambda 表達式與變數作用域:為什麼Local ≠ Instance在Java 中使用lambda 表達式時,一個常見的困惑點是為什麼局部變數需要終結,而實例變數需要終結不要。本文旨在闡明這種差異背後的根本原因。 局部變數:最終性指令在 lambda 表達式中,局部變數必須標記為 Final 以...
    程式設計 發佈於2024-11-08
  • CKA 全程課程日 為什麼要使用 Kubernetes?
    CKA 全程課程日 為什麼要使用 Kubernetes?
    那么,您可能已经使用 Docker 容器有一段时间了,对吧?我知道旋转第一个容器的兴奋感就像魔法一样,但随后现实袭来。您开始注意到大规模管理容器很快就会成为物流噩梦。就在那时,Kubernetes(K8s)像经验丰富的项目经理一样进入房间,准备接管并简化一切。 在这篇文章中,我们将探讨独立容器面临的...
    程式設計 發佈於2024-11-08
  • 簡要封裝範例
    簡要封裝範例
    書包: 這個範例會建立一個名為 bookpack 的包,其中包含一個用於管理書籍資料庫的簡單類別。 圖書類別: 它有私有屬性 title、author 和 pubDate(標題、作者和出版日期)。 構造方法初始化屬性。 show() 方法顯示書籍詳細資料。 BookDemo類別: 建立一個包...
    程式設計 發佈於2024-11-08
  • 適用於 AWS 雲端的簡單 SaaS 的技術堆疊
    適用於 AWS 雲端的簡單 SaaS 的技術堆疊
    介绍 注1:这里是托管的交互式演示:demo.saasconstruct.com 注 2:我每个 SaaS 设置的每月账单为 3-5 美元,其中大部分是 CI/CD 成本。 注3:模板在这里:saasconstruct.com。 我在 AWS 上完成了多个 AI PoC 和 MVP...
    程式設計 發佈於2024-11-08
  • 為什麼在事件處理程序中使用箭頭函數時「this」會出現意外行為?
    為什麼在事件處理程序中使用箭頭函數時「this」會出現意外行為?
    JavaScript - 箭頭函數與事件處理程序當使用箭頭函數作為事件處理程序的回調時,函數中的 this 值是意外的。這篇部落格文章解釋了此行為背後的原因,並提供了使用event.currentTarget.箭頭函數和詞法作用域存取預期元素的解決方案與常規函數不同,箭頭函數沒有其自己的上下文或範圍...
    程式設計 發佈於2024-11-08
  • Aurora PostgreSQL 掌握:讓您的團隊喜極而泣的防彈 Java 模型和 DAO
    Aurora PostgreSQL 掌握:讓您的團隊喜極而泣的防彈 Java 模型和 DAO
    听着,代码骑师。我即将提供一些知识,帮助您将 Aurora PostgreSQL 游戏从业余游戏转变为大联盟游戏。我们谈论的是 Java 模型和数据库访问器,它们会让您的高级开发人员喜极而泣,而您的 DBA 是否会给您买啤酒(取决于您的年龄)。 为什么这很重要: 性能:草率的模型和 ...
    程式設計 發佈於2024-11-08
  • 瞭解後端開發中的責任鏈設計模式
    瞭解後端開發中的責任鏈設計模式
    责任链 (CoR) 设计模式是一种强大的行为模式,可以显着增强后端开发。此模式允许您通过处理程序链传递请求,其中每个处理程序可以处理请求或将其传递到下一个处理程序。在本博客中,我们将从后端角度探讨 CoR 模式,特别关注其在 Web 服务中的请求验证和处理中的应用,并使用 Java 作为示例。 ...
    程式設計 發佈於2024-11-08
  • 深入研究&#專案:大學資訊查詢系統&# - 掌握 Java 和 MySQL 進行高效資料管理
    深入研究&#專案:大學資訊查詢系統&# - 掌握 Java 和 MySQL 進行高效資料管理
    透過「專案:大學資訊查詢系統」釋放資料管理的力量 - 這是一門綜合課程,引導您完成使用 Java 和 MySQL 建立強大的資訊查詢系統的過程。這種基於專案的學習體驗旨在讓您掌握將 Java 應用程式連接到 MySQL 資料庫、執行 SQL 查詢和有效檢索資料所需的基本技能。 課程...
    程式設計 發佈於2024-11-08
  • 使用 PHP 和 JavaScript 將網頁下載為 PDF
    使用 PHP 和 JavaScript 將網頁下載為 PDF
    在 PHP 中將 HTML 轉換為 PDF 很容易。讓我們更進一步,使用 PHP 和 JavaScript 將網頁轉換為 PDF 檔案。 為此,您需要安裝 Composer 和 Node。 安裝這些東西後,您需要使用 Composer 安裝 Dompdf,並使用 npm(Node 套件管理器)...
    程式設計 發佈於2024-11-08
  • 4 年內建構 AI 代理的頂級框架
    4 年內建構 AI 代理的頂級框架
    Hola,我是 Nomadev!如果您像我一样,您可能已经注意到人工智能代理正在席卷世界。说真的,人工智能代理不仅仅是炒作,它们已经在为智能系统提供动力、自动化任务并代表企业做出决策。我一直在深入研究这个领域,相信我,未来是由代理驱动的。 现在,如果您想成为这场革命的一部分并构建自己的人工智能代理...
    程式設計 發佈於2024-11-08
  • 每個開發人員都應該了解的基本 Express 請求屬性
    每個開發人員都應該了解的基本 Express 請求屬性
    在專案後端工作時,處理請求和回應至關重要。有效管理這些請求對於客戶端和伺服器之間的順利通訊至關重要。以下是每個開發人員都應該熟悉的一些常見且重要的請求屬性。 1. 請求ip Express.js 中的 req.ip 是請求物件的屬性,它提供發出請求的客戶端的 IP 位址。它傳回一個...
    程式設計 發佈於2024-11-08
  • 如何解決 Doctrine 左連接期間的「Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got 'ON'\」錯誤?
    如何解決 Doctrine 左連接期間的「Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got 'ON'\」錯誤?
    如何在Doctrine 中執行左連接當使用複雜的資料模型時,有必要透過建立多個表之間的關係來從多個表中檢索資料。左連接允許您從一個表中獲取所有行,並且僅從另一個表中獲取匹配的行。 遇到的問題在Doctrine 中嘗試左連接時可能出現的常見錯誤正在接收以下語法錯誤:[Syntax Error] lin...
    程式設計 發佈於2024-11-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3