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

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

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

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]刪除
最新教學 更多>
  • 什麼是 PATH_INFO 以及它如何增強 PHP Web 應用程式?
    什麼是 PATH_INFO 以及它如何增強 PHP Web 應用程式?
    深入研究PATH_INFO:揭示其在PHP Web 應用程式中的作用在Web 開發領域,PHP 是一個強大的工具,用於建立動態和互動式應用程式。它的全部功能之一是名為 PATH_INFO 的神秘變數。儘管經常被提及,但許多人仍然難以理解其確切作用。本文深入研究 PATH_INFO,闡明其目的、實用程...
    程式設計 發佈於2024-11-08
  • 如何使用 Connector .NET 檢索 MySQL 中的最後一個插入 ID?
    如何使用 Connector .NET 檢索 MySQL 中的最後一個插入 ID?
    使用Connector .NET 在MySql 中檢索最後一個插入ID在MySql 中,最後一個插入ID 是指分配給新插入的標識符排。該值在某些情況下可能很有價值,例如填充外鍵關係。 最初,假設 MySqlHelper 類別的 ExecuteNonQuery 方法傳回最後一個插入 ID。然而,這個假...
    程式設計 發佈於2024-11-08
  • 如何在 PHP 中使用 cURL 取得 API 回應?
    如何在 PHP 中使用 cURL 取得 API 回應?
    在PHP 中使用cURL 取得API 回應在PHP 中,您可以建立一個獨立的類,其中包含透過cURL 呼叫API的函數並獲得響應。以下是實現此目的的方法:class ApiRequest { public function getResponse($url) { // Set cURL ...
    程式設計 發佈於2024-11-08
  • Ansible 入門 - 初學者指南:日復一日的 DevOps 工具系列
    Ansible 入門 - 初學者指南:日復一日的 DevOps 工具系列
    欢迎来到我们的“50 天 50 个 DevOps 工具”系列的第 30 天!今天,我们将探索 Ansible,它是 DevOps 工具包中最重要的工具之一。本博客将向您介绍 Ansible 的基础知识,分解其关键组件并向您展示如何从简单的示例开始。我们会让事情简单明了,使其成为初学者的完美起点。 ...
    程式設計 發佈於2024-11-08
  • 什麼是CPU暫存器
    什麼是CPU暫存器
    什麼是暫存器: 電腦暫存器是電腦中央處理單元 (CPU) 內的小型高速儲存單元,用於暫時保存資料和指令,以便在處理過程中快速存取。它們是直接影響 CPU 運算速度和效率的重要元件。 暫存器的存取速度比記憶體更快,因為它們位於 CPU 內部。這種接近性允許更快的資料檢索和處理。 暫存器記憶體是電腦...
    程式設計 發佈於2024-11-08
  • 折疊還是雙折?這是一個技術問題!
    折疊還是雙折?這是一個技術問題!
    我們現在不能停下來,因為我們已經投資了 1 倍,但多年來讓我們繼續投入 100 倍!斯托克斯! JavaScript 範例 你可能以前聽說過,但 Javascript 是在 10 天內寫成的。它的採用率迅速增長,即使在使用該語言幾年後,他們也不想引入重大變化……所以,現在該語言已經...
    程式設計 發佈於2024-11-08
  • 動態 Getter 和 Setter 如何增強 JavaScript 的靈活性?
    動態 Getter 和 Setter 如何增強 JavaScript 的靈活性?
    在 JavaScript 中實作動態 Getter 和 Setter:指南在傳統 JavaScript 中,getter 和 setter 是為特定屬性名稱定義的。但是,可以使用 ES2015 中引入的代理程式建立更靈活的動態 getter 和 setter。 使用代理的動態 getter 和 se...
    程式設計 發佈於2024-11-08
  • 如何在 Go 中將類型變數傳遞給函數進行類型斷言?
    如何在 Go 中將類型變數傳遞給函數進行類型斷言?
    將類型變數傳遞給函數進行型別斷言您希望透過將型別傳遞給函式來執行型別斷言。本質上,您的目標是實現以下目標:// Note that this is pseudocode, because Type isn't valid here func myfunction(mystring string, m...
    程式設計 發佈於2024-11-08
  • 從輸入欄位取得文字..
    從輸入欄位取得文字..
    Java代碼 public class MainActivity extends AppCompatActivity { Button btn; TextView textView; @Override protected void onCreate(Bundle s...
    程式設計 發佈於2024-11-08
  • PSD 批次編輯器
    PSD 批次編輯器
    大家好!我正在分享我在過去幾個月開發的這個新軟體。 我希望它可以幫助一些人,有些人可能有興趣幫助我改進它。我想添加很多功能,所以請隨時告訴我您希望在軟體中看到什麼。 在技術方面,我開始這個專案是為了嘗試在我的程式碼中實現一些設計模式,並更好地建立架構。這也是我第一次使用QT(我在過去的GUI專案...
    程式設計 發佈於2024-11-08
  • 為什麼 WinAPI Sleep(1) 會導致 15 毫秒暫停?
    為什麼 WinAPI Sleep(1) 會導致 15 毫秒暫停?
    了解WinAPI Sleep() 函數持續時間的差異當以1 毫秒為參數呼叫WinAPI Sleep() 函數時,據觀察,執行緒實際上暫停的時間要長得多,通常約為15 毫秒。這種現象引起了人們對潛在系統問題的擔憂。 Windows 中的時間量化Windows 採用時間量化機制進行執行緒調度。這意味著系...
    程式設計 發佈於2024-11-08
  • 以下是一些符合條件的標題選項: 

* JavaScript 中的相對路徑與絕對路徑:何時使用哪一個?
* JavaScript 路徑:絕對路徑還是相對路徑?性能和安全指南。
* 瓦時
    以下是一些符合條件的標題選項: * JavaScript 中的相對路徑與絕對路徑:何時使用哪一個? * JavaScript 路徑:絕對路徑還是相對路徑?性能和安全指南。 * 瓦時
    澄清 JavaScript 中的相對路徑和絕對路徑相對路徑和絕對路徑是 Web 開發中的基本概念,理解它們的差異至關重要。 定義絕對路徑指定相對於根目錄的位置(例如,/images/kitten.png)。另一方面,相對路徑指定相對於目前工作目錄的位置(例如,kitten.png)。 效能注意事項相...
    程式設計 發佈於2024-11-08
  • 如何處理 MySQL 查詢中的外鍵插入:兩種常見場景
    如何處理 MySQL 查詢中的外鍵插入:兩種常見場景
    如何處理MySQL 查詢中的外鍵插入為了有效地將值插入到具有外鍵的表中,讓我們探討兩個常見的場景:場景1:新增學生和現有教師要將新學生連結到現有教師,請使用教師姓名檢索外鍵:INSERT INTO TAB_STUDENT(name_student, id_teacher_fk) SELECT 'Jo...
    程式設計 發佈於2024-11-08
  • std::lock_guard 與 std::scoped_lock:何時選擇哪一個?
    std::lock_guard 與 std::scoped_lock:何時選擇哪一個?
    考慮std::lock_guard 與std::scoped_lockC 17 標誌著引入了一個新穎的鎖類std::scoped_lock ,它與古老的std::lock_guard 有相似之處。本文深入探討了這兩種鎖定機制之間的區別,引導您選擇適合您特定需求的最佳工具。 何時使用std::lock...
    程式設計 發佈於2024-11-08
  • 如何使用 Java 和 Apache Tika 從 Zip 檔案中的檔案中提取內容?
    如何使用 Java 和 Apache Tika 從 Zip 檔案中的檔案中提取內容?
    如何使用Java 和Apache Tika 從Zip 檔案中的檔案讀取和提取內容實作從Zip 檔案中讀取和提取內容的任務使用Java 和Apache Tika 壓縮zip 檔案中的檔案涉及幾個關鍵步驟。 1。初始化輸入首先從要處理的檔案建立輸入流:InputStream input = new Fi...
    程式設計 發佈於2024-11-08

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

Copyright© 2022 湘ICP备2022001581号-3