JavaScript 原型和原型鏈

来源:https://www.cnblogs.com/yuzhihui/archive/2023/01/12/17047616.html
-Advertisement-
Play Games

JavaScript 是一種基於原型繼承的語言。在 JavaScript 中,對象是通過原型鏈來繼承屬性和方法的。 一、原型 每一個對象都有一個 proto 屬性,該屬性指向該對象的原型。原型本質上也是一個對象,所有的對象都擁有一個原型,除了 Object.prototype。 JavaScript ...


JavaScript 是一種基於原型繼承的語言。在 JavaScript 中,對象是通過原型鏈來繼承屬性和方法的。

一、原型

每一個對象都有一個 proto 屬性,該屬性指向該對象的原型。原型本質上也是一個對象,所有的對象都擁有一個原型,除了 Object.prototype。

JavaScript 中有一個 Object.create() 方法可以用來創建一個新對象,並且可以指定該對象的原型。

例如:

let obj1 = {
  name: "object1",
  sayName: function() {
    console.log(this.name);
  }
};

let obj2 = Object.create(obj1);
console.log(obj2.name);  // "object1"
obj2.sayName(); // "object1"

在上面代碼中,obj2 是通過 obj1 創建的,obj2 的原型是 obj1,所以 obj2 可以繼承 obj1 的屬性和方法。

二、原型鏈

原型鏈是一種鏈式結構,它描述了對象與其原型之間的關係。當對象訪問一個屬性或方法時,如果在自身中找不到,就會在其原型中尋找,如果在原型中還找不到,就會繼續在原型的原型中尋找,直到找到為止或者到達原型鏈的頂端(Object.prototype)。

在 JavaScript 中,原型鏈的頂端是 Object.prototype,它是所有對象的根原型。Object.prototype 上面沒有原型了。

同時原型鏈也可能會出現迴圈引用的情況,所以在使用原型鏈時需要註意避免這種情況。

JavaScript 中的原型和原型鏈是 JavaScript 中非常重要的一部分,它們是 JavaScript 繼承的基礎。在 JavaScript 中,所有的對象都是通過原型繼承來繼承屬性和方法的,這樣能夠節省記憶體空間和提高代碼復用性。

三、繼承

對於 JavaScript 的繼承來說,原型鏈是其中一種常用的方式,還有一種是 ES6 中新增的類和繼承的概念。

ES6 中的 class 和 extends 關鍵字可以用來定義類和繼承。這種方式和原型鏈繼承本質上是一樣的,只是語法上更加類似傳統面向對象語言。

例如:

class Parent {
  constructor(name) {
    this.name = name;
  }
  sayName() {
    console.log(this.name);
  }
}

class Child extends Parent {
  constructor(name, age) {
    super(name);
    this.age = age;
  }
  sayAge() {
    console.log(this.age);
  }
}

let child = new Child("Bob", 10);
child.sayName(); // "Bob"
child.sayAge(); // 10

在上面的代碼中,使用 class 和 extends 關鍵字定義了一個父類 Parent 和一個子類 Child。Child 類繼承了 Parent 類,也就是說 Child 對象可以繼承 Parent 對象的屬性和方法。

constructor 是類的構造函數,在使用 new 創建類的實例時會調用該函數。在子類中,使用 super(name) 調用父類的構造函數,這樣可以繼承父類的屬性。

在子類中可以添加新的屬性和方法,例如 sayAge 方法,這樣就實現了對父類的繼承和擴展。

JavaScript 的原型鏈和 ES6 中的 class 和 extends 都是實現繼承的方式。其中原型鏈繼承更加靈活,對於繼承和擴展都比較方便,但是語法上比較麻煩。而 class 和 extends 的語法更加類似傳統面向對象語言,更加易於理解,但是在繼承和擴展上比較限制。

作者:yuzhihui
出處:http://www.cnblogs.com/yuzhihui/ 聲明:歡迎任何形式的轉載,但請務必註明出處!!!
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 二分查找(Binary Search)是一種在有序數組中查找目標元素的查找演算法。它的基本思路是:在數組的中間元素開始,如果該元素等於目標元素,則查找成功;如果該元素大於目標元素,則在左半部分繼續查找;如果該元素小於目標元素,則在右半部分繼續查找。這樣一直重覆這個過程,直到查找成功或者查找失敗。 ...
  • 摘要:讓我們看一個示例,展示在記憶體消耗方面,採用流的編程思路帶來的巨大優越性。 本文分享自華為雲社區《使用 Node.js Stream API 減少伺服器端記憶體消耗的一個具體例子》,作者:Jerry Wang 。 HTTP 響應對象(上面代碼中的 res)也是一個可寫流。這意味著如果我們有一個表示 ...
  • upload上傳組件的使用方法 上傳圖片後自動上傳(也可以手動上傳),圖片上傳成功後由後端返回特定圖片地址,在表單提交後將表單數據同圖片地址一併返回即可完成圖片上傳功能。 組件HTML <!-- 上傳圖片 --> <div style="margin: 4px 0">圖片上傳(僅支持jpg、png格 ...
  • 參考sapui5 TreeTable控制項的示例,我們發現所有的可展開列(即所謂的hierarchical data column)預設都在第一列,而且API中並沒有給出對應的屬性或方法來重新指定可展開列在table中的位置。 我們可以編寫一個自定義控制項,使其繼承sapui5的TreeTable控制項, ...
  • AngularJS——初識AngularJS AngularJS是什麼 AngularJS是Google開源的一款前端JS結構化框架,它通過對前端開發進行分層,極好地規範了前端開發的風格——它將前端開發分為Controller層、Service層、DAO層和Model層。其中,Model對象與HTM ...
  • JavaScript 面向切麵編程 (AOP) 是一種編程思想和實現方式,它將一些關註點(例如日誌記錄、安全性檢查、性能監控等)從主題對象中分離出來,通過“橫切關註點”的方式在程式中動態地織入這些關註點。這樣可以避免在主題對象中嵌入大量的關註點代碼,使得代碼更加簡潔和可維護。 ...
  • CSS Grid 佈局是一種二維佈局方式,可以將頁面分成行和列,併在其中放置元素。使用 Grid 佈局時,需要定義網格容器和網格項目。 ...
  • Axios 1.基本說明 Axios是一個基於promise的網路請求庫,作用於node.js和瀏覽器中。它是 isomorphic 的 (即同一套代碼可以運行在瀏覽器和node.js中)。在服務端它使用原生node.js http 模塊, 而在客戶端 (瀏覽端) 則使用XMLHttpRequest ...
一周排行
    -Advertisement-
    Play Games
  • 前言 在我們開發過程中基本上不可或缺的用到一些敏感機密數據,比如SQL伺服器的連接串或者是OAuth2的Secret等,這些敏感數據在代碼中是不太安全的,我們不應該在源代碼中存儲密碼和其他的敏感數據,一種推薦的方式是通過Asp.Net Core的機密管理器。 機密管理器 在 ASP.NET Core ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 順序棧的介面程式 目錄順序棧的介面程式頭文件創建順序棧入棧出棧利用棧將10進位轉16進位數驗證 頭文件 #include <stdio.h> #include <stdbool.h> #include <stdlib.h> 創建順序棧 // 指的是順序棧中的元素的數據類型,用戶可以根據需要進行修改 ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • C總結與剖析:關鍵字篇 -- <<C語言深度解剖>> 目錄C總結與剖析:關鍵字篇 -- <<C語言深度解剖>>程式的本質:二進位文件變數1.變數:記憶體上的某個位置開闢的空間2.變數的初始化3.為什麼要有變數4.局部變數與全局變數5.變數的大小由類型決定6.任何一個變數,記憶體賦值都是從低地址開始往高地 ...
  • 如果讓你來做一個有狀態流式應用的故障恢復,你會如何來做呢? 單機和多機會遇到什麼不同的問題? Flink Checkpoint 是做什麼用的?原理是什麼? ...
  • C++ 多級繼承 多級繼承是一種面向對象編程(OOP)特性,允許一個類從多個基類繼承屬性和方法。它使代碼更易於組織和維護,並促進代碼重用。 多級繼承的語法 在 C++ 中,使用 : 符號來指定繼承關係。多級繼承的語法如下: class DerivedClass : public BaseClass1 ...
  • 前言 什麼是SpringCloud? Spring Cloud 是一系列框架的有序集合,它利用 Spring Boot 的開發便利性簡化了分散式系統的開發,比如服務註冊、服務發現、網關、路由、鏈路追蹤等。Spring Cloud 並不是重覆造輪子,而是將市面上開發得比較好的模塊集成進去,進行封裝,從 ...
  • class_template 類模板和函數模板的定義和使用類似,我們已經進行了介紹。有時,有兩個或多個類,其功能是相同的,僅僅是數據類型不同。類模板用於實現類所需數據的類型參數化 template<class NameType, class AgeType> class Person { publi ...
  • 目錄system v IPC簡介共用記憶體需要用到的函數介面shmget函數--獲取對象IDshmat函數--獲得映射空間shmctl函數--釋放資源共用記憶體實現思路註意 system v IPC簡介 消息隊列、共用記憶體和信號量統稱為system v IPC(進程間通信機制),V是羅馬數字5,是UNI ...