精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一篇文章告訴你JavaScript如何實現繼承

開發 前端
JavaScript 在編程語言界是個特殊種類,它和其他編程語言很不一樣,JavaScript 可以在運行的時候動態地改變某個變量的類型。

[[433254]]

背景簡介

JavaScript 在編程語言界是個特殊種類,它和其他編程語言很不一樣,JavaScript 可以在運行的時候動態地改變某個變量的類型。

比如你永遠也沒法想到像isTimeout這樣一個變量可以存在多少種類型,除了布爾值true和false,它還可能是undefined、1和0、一個時間戳,甚至一個對象。

如果代碼跑異常,打開瀏覽器,開始斷點調試,發現InfoList這個變量第一次被賦值的時候是個數組:

  1. [{name'test1', value: '11'}, {name'test2', value: '22'}] 

過了一會竟然變成了一個對象:

  1. {test1:'11', test2: '22'

除了變量可以在運行時被賦值為任何類型以外,JavaScript 中也能實現繼承,但它不像 Java、C++、C# 這些編程語言一樣基于類來實現繼承,而是基于原型進行繼承。

這是因為 JavaScript 中有個特殊的存在:對象。每個對象還都擁有一個原型對象,并可以從中繼承方法和屬性。

提到對象和原型,有如下問題:

  • JavaScript 的函數怎么也是個對象?
  • proto和prototype到底是啥關系?
  • JavaScript 中對象是怎么實現繼承的?
  • JavaScript 是怎么訪問對象的方法和屬性的?

原型對象和對象的關系

在 JavaScript 中,對象由一組或多組的屬性和值組成:

  1.   key1: value1, 
  2.   key2: value2, 
  3.   key3: value3, 

在 JavaScript 中,對象的用途很是廣泛,因為它的值既可以是原始類型(number、string、boolean、null、undefined、bigint和symbol),還可以是對象和函數。

不管是對象,還是函數和數組,它們都是Object的實例,也就是說在 JavaScript 中,除了原始類型以外,其余都是對象。

這也就解答了問題1:JavaScript 的函數怎么也是個對象?

在 JavaScript 中,函數也是一種特殊的對象,它同樣擁有屬性和值。所有的函數會有一個特別的屬性prototype,該屬性的值是一個對象,這個對象便是我們常說的“原型對象”。

我們可以在控制臺打印一下這個屬性:

  1. function Person(name) { 
  2.   this.name = name
  3. console.log(Person.prototype); 

打印結果顯示為:

可以看到,該原型對象有兩個屬性:constructor和proto。

到這里,我們仿佛看到疑惑 “2:proto和prototype到底是啥關系?”的答案要出現了。在 JavaScript 中,proto屬性指向對象的原型對象,對于函數來說,它的原型對象便是prototype。函數的原型對象prototype有以下特點:

  • 默認情況下,所有函數的原型對象(prototype)都擁有constructor屬性,該屬性指向與之關聯的構造函數,在這里構造函數便是Person函數;
  • Person函數的原型對象(prototype)同樣擁有自己的原型對象,用proto屬性表示。前面說過,函數是Object的實例,因此Person.prototype的原型對象為Object.prototype。

我們可以用這樣一張圖來描述prototype、proto和constructor三個屬性的關系:

從這個圖中,我們可以找到這樣的關系:

  • 在 JavaScript 中,proto屬性指向對象的原型對象;
  • 對于函數來說,每個函數都有一個prototype屬性,該屬性為該函數的原型對象;

使用 prototype 和 proto 實現繼承

對象之所以使用廣泛,是因為對象的屬性值可以為任意類型。因此,屬性的值同樣可以為另外一個對象,這意味著 JavaScript 可以這么做:通過將對象 A 的proto屬性賦值為對象 B,即:

  1. A.__proto__ = B 

此時使用A.proto便可以訪問 B 的屬性和方法。

這樣,JavaScript 可以在兩個對象之間創建一個關聯,使得一個對象可以訪問另一個對象的屬性和方法,從而實現了繼承;

使用prototype和proto實現繼承

以Person為例,當我們使用new Person()創建對象時,JavaScript 就會創建構造函數Person的實例,比如這里我們創建了一個叫“zhangsan”的Person:

  1. var zhangsan = new Person("zhangsan"); 

上述這段代碼在運行時,JavaScript 引擎通過將Person的原型對象prototype賦值給實例對象zhangsan的proto屬性,實現了zhangsan對Person的繼承,即執行了以下代碼:

  1. //JavaScript 引擎執行了以下代碼 
  2. var zhangsan = {}; 
  3. zhangsan.__proto__ = Person.prototype; 
  4. Person.call(zhangsan, "zhangsan"); 

我們來打印一下zhangsan實例:

  1. console.log(zhangsan) 

結果如下圖所示:

可以看到,zhangsan作為Person的實例對象,它的proto指向了Person的原型對象,即Person.prototype。

這時,我們再補充下上圖中的關系:

從這幅圖中,我們可以清晰地看到構造函數和constructor屬性、原型對象(prototype)和proto、實例對象之間的關系,這是很多容易混淆。根據這張圖,我們可以得到以下的關系:

  • 每個函數的原型對象(Person.prototype)都擁有constructor屬性,指向該原型對象的構造函數(Person);
  • 使用構造函數(new Person())可以創建對象,創建的對象稱為實例對象(lily);
  • 實例對象通過將proto屬性指向構造函數的原型對象(Person.prototype),實現了該原型對象的繼承。

那么現在,關于proto和prototype的關系,我們可以得到這樣的答案:

  • 每個對象都有proto屬性來標識自己所繼承的原型對象,但只有函數才有prototype屬性;
  • 對于函數來說,每個函數都有一個prototype屬性,該屬性為該函數的原型對象;
  • 通過將實例對象的proto屬性賦值為其構造函數的原型對象prototype,JavaScript 可以使用構造函數創建對象的方式,來實現繼承。

所以一個對象可通過proto訪問原型對象上的屬性和方法,而該原型同樣也可通過proto訪問它的原型對象,這樣我們就在實例和原型之間構造了一條原型鏈。紅色線條所示:

通過原型鏈訪問對象的方法和屬性

當 JavaScript 試圖訪問一個對象的屬性時,會基于原型鏈進行查找。查找的過程是這樣的:

  • 首先會優先在該對象上搜尋。如果找不到,還會依次層層向上搜索該對象的原型對象、該對象的原型對象的原型對象等(套娃告警);
  • JavaScript 中的所有對象都來自Object,Object.prototype.proto === null。null沒有原型,并作為這個原型鏈中的最后一個環節;
  • JavaScript 會遍歷訪問對象的整個原型鏈,如果最終依然找不到,此時會認為該對象的屬性值為undefined。

我們可以通過一個具體的例子,來表示基于原型鏈的對象屬性的訪問過程,在該例子中我們構建了一條對象的原型鏈,并進行屬性值的訪問:

  1. var o = {a: 1, b: 2}; // 讓我們假設我們有一個對象 o, 其有自己的屬性 a 和 b: 
  2. o.__proto__ = {b: 3, c: 4}; // o 的原型 o.__proto__有屬性 b 和 c: 

當我們在獲取屬性值的時候,就會觸發原型鏈的查找:

  1. console.log(o.a); // o.a => 1 
  2. console.log(o.b); // o.b => 2 
  3. console.log(o.c); // o.c => o.__proto__.c => 4 
  4. console.log(o.d); // o.c => o.__proto__.d => o.__proto__.__proto__ == null => undefined 

綜上,整個原型鏈如下:

  1. {a:1, b:2} ---> {b:3, c:4} ---> null, // 這就是原型鏈的末尾,即 null 

可以看到,當我們對對象進行屬性值的獲取時,會觸發該對象的原型鏈查找過程。

既然 JavaScript 中會通過遍歷原型鏈來訪問對象的屬性,那么我們可以通過原型鏈的方式進行繼承。

也就是說,可以通過原型鏈去訪問原型對象上的屬性和方法,我們不需要在創建對象的時候給該對象重新賦值/添加方法。比如,我們調用lily.toString()時,JavaScript 引擎會進行以下操作:

  • 先檢查lily對象是否具有可用的toString()方法;
  • 如果沒有,則``檢查lily的原型對象(Person.prototype)是否具有可用的toString()方法;
  • 如果也沒有,則檢查Person()構造函數的prototype屬性所指向的對象的原型對象(即Object.prototype)是否具有可用的toString()方法,于是該方法被調用。

由于通過原型鏈進行屬性的查找,需要層層遍歷各個原型對象,此時可能會帶來性能問題:

  • 當試圖訪問不存在的屬性時,會遍歷整個原型鏈;
  • 在原型鏈上查找屬性比較耗時,對性能有副作用,這在性能要求苛刻的情況下很重要。

因此,我們在設計對象的時候,需要注意代碼中原型鏈的長度。當原型鏈過長時,可以選擇進行分解,來避免可能帶來的性能問題。

其他方式實現繼承

除了通過原型鏈的方式實現 JavaScript 繼承,JavaScript 中實現繼承的方式還包括經典繼承(盜用構造函數)、組合繼承、原型式繼承、寄生式繼承,等等。

  • 原型鏈繼承方式中引用類型的屬性被所有實例共享,無法做到實例私有;
  • 經典繼承方式可以實現實例屬性私有,但要求類型只能通過構造函數來定義;

組合繼承融合原型鏈繼承和構造函數的優點,它的實現如下:

  1. function Parent(name) { 
  2.   // 私有屬性,不共享 
  3.   this.name = name
  4. // 需要復用、共享的方法定義在父類原型上 
  5. Parent.prototype.speak = function() { 
  6.   console.log("hello"); 
  7. }; 
  8. function Child(name) { 
  9.   Parent.call(this, name); 
  10. // 繼承方法 
  11. Child.prototype = new Parent(); 

組合繼承模式通過將共享屬性定義在父類原型上、將私有屬性通過構造函數賦值的方式,實現了按需共享對象和方法,是 JavaScript 中最常用的繼承模式。

雖然在繼承的實現方式上有很多種,但實際上都離不開原型對象和原型鏈的內容,因此掌握proto和prototype、對象的繼承等這些知識,是我們實現各種繼承方式的前提條件。

總結

關于 JavaScript 的原型和繼承,常常會在我們面試題中出現。隨著 ES6/ES7 等新語法糖的出現,可能更傾向于使用class/extends等語法來編寫代碼,原型繼承等概念逐漸變淡。 

其次JavaScript 的設計在本質上依然沒有變化,依然是基于原型來實現繼承的。如果不了解這些內容,可能在我們遇到一些超出自己認知范圍的內容時,很容易束手無策。

 

責任編輯:武曉燕 來源: IT共享之家
相關推薦

2022-02-18 00:13:53

JavaScript編程語言數組

2019-07-28 20:15:07

2023-06-21 00:10:17

JSONWeb服務器JavaScript

2020-11-13 08:14:28

JavaScript

2021-12-28 09:27:45

Javascript 高階函數前端

2021-01-20 05:35:08

PythonMock微服務

2019-10-17 19:15:22

jQueryJavaScript前端

2020-10-22 08:25:22

JavaScript運作原理

2021-02-02 18:39:05

JavaScript

2021-01-29 18:41:16

JavaScript函數語法

2021-06-04 09:56:01

JavaScript 前端switch

2020-11-10 10:48:10

JavaScript屬性對象

2023-09-06 14:57:46

JavaScript編程語言

2021-06-24 09:05:08

JavaScript日期前端

2021-03-05 18:04:15

JavaScript循環代碼

2021-03-09 14:04:01

JavaScriptCookie數據

2021-01-26 23:46:32

JavaScript數據結構前端

2023-07-30 15:18:54

JavaScript屬性

2024-01-30 13:47:45

2024-04-19 14:23:52

SwitchJavaScript開發
點贊
收藏

51CTO技術棧公眾號

欧美老女人性生活| 欧美自拍偷拍一区| 国产精品.com| 天堂网一区二区三区| 欧美大奶一区二区| 在线精品视频免费播放| 日本黄色播放器| 成人免费公开视频| 久久久久欧美精品| 北条麻妃久久精品| 制服丝袜第一页在线观看| 婷婷综合六月| 一区二区三区色| 欧美精品一区二区三区在线看午夜| 日日夜夜狠狠操| 91精品婷婷色在线观看| 亚洲国产三级网| 午夜两性免费视频| 色呦呦在线看| 亚洲国产精品v| 成人欧美一区二区三区视频xxx| 国产精品suv一区| 中文精品电影| 国产一区二区美女视频| 古装做爰无遮挡三级聊斋艳谭| 亚洲福利影院| 一区二区三区日韩| 日本午夜精品电影| 成人精品在线播放| 久久se精品一区精品二区| 欧美激情中文字幕在线| 国产午夜精品久久久久久久久| 久久九九热re6这里有精品| 欧美午夜在线观看| 男人天堂1024| www.8ⅹ8ⅹ羞羞漫画在线看| 欧美高清在线一区二区| 精品欧美一区二区精品久久| 国产高清视频免费| 久久国产精品72免费观看| 57pao成人国产永久免费| 欧美日韩大片在线观看| 精品久久美女| 亚洲精品影视在线观看| 稀缺呦国内精品呦| 国产精品亚洲一区二区在线观看| 在线观看国产91| 成人免费在线小视频| 青草视频在线免费直播| 亚洲精品视频一区二区| 国产又黄又爽免费视频| avtt亚洲| 中文字幕不卡的av| 日韩精品久久久| 国产午夜在线视频| 久久久精品天堂| 久久精品日产第一区二区三区精品版| 亚洲va天堂va欧美ⅴa在线| 久久99蜜桃精品| 国产剧情日韩欧美| 亚洲天堂999| 久久精品国产久精国产| 国产精品女主播视频| 国产乱码在线观看| 日韩av中文字幕一区二区| 日韩美女av在线免费观看| 天天综合网久久综合网| 亚洲一区日本| 日av在线播放中文不卡| 亚洲中文字幕无码爆乳av| 噜噜噜久久亚洲精品国产品小说| 欧美中文在线观看国产| 久久久精品福利| 麻豆亚洲精品| 国产精品免费一区豆花| 一本色道久久综合精品婷婷| 精品一区二区三区免费视频| 成人精品在线观看| www.亚洲黄色| av一二三不卡影片| 欧美日韩一区二区视频在线| 爱久久·www| 一区二区中文视频| 欧美另类videosbestsex日本| 午夜成年人在线免费视频| 亚洲综合男人的天堂| 成人免费观看cn| 成人小电影网站| 欧美日韩视频一区二区| 三日本三级少妇三级99| 久久精品亚洲成在人线av网址| 亚洲视频999| 在线视频这里只有精品| 精品成人在线| 国产v综合v亚洲欧美久久| 亚洲熟妇av乱码在线观看| 国产精品一区二区视频| 久久精品国产美女| 免费大片在线观看www| 亚洲在线视频一区| 亚洲 中文字幕 日韩 无码| 久久亚洲资源中文字| 日韩欧美国产精品一区| 亚洲一区二区观看| 中文字幕一区二区精品区| 国内精品一区二区三区四区| 中文字幕人妻一区二区三区视频| 国产精品99久久久久久久女警 | 精品女同一区二区三区在线观看| 欧美一区午夜精品| 女~淫辱の触手3d动漫| 久久久久蜜桃| 日韩免费在线免费观看| www.色视频| 国产精品国产三级国产普通话蜜臀 | 亚洲精品视频一区二区| 别急慢慢来1978如如2| 涩爱av色老久久精品偷偷鲁| 国产亚洲精品高潮| 亚洲欧美在线视频免费| 老司机免费视频一区二区三区| 国内视频一区二区| 91cn在线观看| 欧美日韩国产高清一区| 亚洲蜜桃精久久久久久久久久久久| 日韩久久综合| 日韩av成人在线观看| 丰满人妻一区二区| 国产精品久久久久毛片软件| 激情六月丁香婷婷| 国产成人精品亚洲线观看| 久久精品色欧美aⅴ一区二区| 日韩精品一区不卡| 99精品国产热久久91蜜凸| av影院在线播放| 91视频亚洲| 日韩中文理论片| 无码人妻精品一区二区三区蜜桃91 | 久久av影视| 91极品女神在线| 亚洲国产www| 一区二区三区四区av| 婷婷激情5月天| 日韩欧美三级| 国产精品免费看久久久香蕉| 国产毛片在线| 在线免费视频一区二区| 最近中文字幕免费视频| 亚洲国产一区二区三区a毛片 | 国产精品玖玖玖在线资源| 久久中文字幕在线| 99久久国产免费| 亚洲日本在线a| 韩国一区二区在线播放| 在线免费观看日本欧美爱情大片| 91精品久久久久久久久久| 69久久久久| 欧美男生操女生| 婷婷国产成人精品视频| 久久99国产乱子伦精品免费| 欧美日韩一级在线| 国产中文欧美日韩在线| 欧美大成色www永久网站婷| aaa一区二区三区| 亚洲影视在线播放| 亚洲国产精品成人综合久久久| 亚洲欧洲视频| 欧美成熟毛茸茸复古| 久久xxx视频| 久久精品一区中文字幕| 亚洲爆乳无码一区二区三区| 天天综合天天综合色| 强伦人妻一区二区三区| 日本视频免费一区| 看一级黄色录像| 欧美1区二区| 国产精品福利无圣光在线一区| 调教视频免费在线观看| 91精品国产欧美一区二区成人 | 成年人在线观看av| 日韩精品国产欧美| 浴室偷拍美女洗澡456在线| 成人午夜大片| 国产999在线| 成人三级网址| 亚洲国产成人精品电影| 一级一级黄色片| 亚洲精品一二三四区| 亚洲av网址在线| 美女爽到高潮91| 日韩视频在线视频| 日本欧美国产| 成人高清在线观看| 9999精品成人免费毛片在线看| 日韩成人黄色av| www.亚洲激情| 国产精品国产| 综合网中文字幕| 天天爽天天爽天天爽| 国产91丝袜在线播放九色| 亚洲国产精品无码观看久久| 亚欧洲精品视频在线观看| 国产精品成人在线| 伦理片一区二区三区| 91精品婷婷国产综合久久| 久久在线视频精品| 久久综合九色欧美综合狠狠| 奇米影视四色在线| 国产午夜精品一区二区三区欧美| 日本精品一区二区三区高清 久久 日本精品一区二区三区不卡无字幕 | 91精品国产91久久综合桃花| 久久国产免费观看| 国产三级精品在线| 91蝌蚪视频在线| 国产乱码精品| 欧美少妇一区二区三区| japanese国产精品| 国产不卡一区二区在线观看| 欧美色999| 久久免费少妇高潮久久精品99| 风间由美一区| 精品国产伦一区二区三区免费| 丁香社区五月天| 亚洲综合无码一区二区| 超碰人人干人人| 91在线一区二区| 欧美图片自拍偷拍| 另类专区欧美蜜桃臀第一页| 男女超爽视频免费播放| 99精品视频在线| 天堂资源在线亚洲资源| www.成人网| 国产美女精品免费电影| 老司机深夜福利在线观看| 欧美第一页在线| 午夜视频成人| 亚洲三级 欧美三级| 黄片毛片在线看| 欧美成人激情免费网| 一级全黄少妇性色生活片| 欧美日韩日本国产| 久久一二三四区| 亚洲大片一区二区三区| 久热这里有精品| 国产精品成人午夜| 91精品人妻一区二区三区蜜桃欧美| 成人美女在线视频| 日本wwwxx| 国产做a爰片久久毛片| 欧美牲交a欧美牲交| 国产亚洲毛片| 欧美精品自拍视频| 欧美日韩日本国产亚洲在线| 亚洲精品久久久久久一区二区| 欧美日韩导航| 精品国产乱码久久久久久蜜柚| 中文字幕视频精品一区二区三区| 国产精品久久久久久一区二区 | 欧美在线激情网| 2020国产在线| 欧美激情视频网站| 日韩专区av| 欧美成人剧情片在线观看| 免费av网站在线看| 欧美成人手机在线| 久草免费在线观看| 日韩中文字幕视频在线| 天堂中文а√在线| 欧美国产日韩二区| 成人影音在线| 午夜精品蜜臀一区二区三区免费| 中文字幕在线高清| 日本成人黄色片| 日韩欧美精品电影| 国产精品亚洲片夜色在线| 精品国产乱码一区二区三区| 亚洲中国色老太| 日韩最新av| 欧美亚洲丝袜| 欧美精品一二| 在线视频精品一区| 欧美日韩国产亚洲一区| 色综合av综合无码综合网站| 日韩中文字幕麻豆| 国产一级片自拍| 成人激情综合网站| 日韩人妻一区二区三区| 欧美国产日韩在线观看| 欧美性x x x| 天天操天天色综合| 亚洲黄网在线观看| 911精品产国品一二三产区| 成人免费公开视频| 亚洲欧美制服综合另类| 99se视频在线观看| 久久高清视频免费| 欧美xxx视频| 91精品中文在线| 国产三级精品三级在线观看国产| 日本一区二区视频| 亚洲深深色噜噜狠狠爱网站| 人人妻人人澡人人爽欧美一区 | 99视频精品免费| 国内久久精品视频| 亚洲一级av无码毛片精品| 亚洲国产经典视频| 校园春色 亚洲| 色综合久久久久久久久久久| 亚洲在线精品视频| 亚洲男人天堂视频| sm国产在线调教视频| 欧美中文字幕在线播放| 欧美另类中文字幕| 麻豆亚洲一区| 欧美1区3d| 9久久9毛片又大又硬又粗| 国内久久精品视频| 国产手机在线观看| 一区二区三区中文在线观看| 最好看的日本字幕mv视频大全| 91精品久久久久久蜜臀| 久香视频在线观看| 久久免费成人精品视频| 国产成人精品一区二区三区免费| 99re在线播放| 日韩高清一级| 国产精品无码免费专区午夜| 免费的国产精品| 成年人的黄色片| 亚洲一区二区精品3399| 最新黄色网址在线观看| 日韩成人小视频| 91九色美女在线视频| 91亚洲永久免费精品| 久久不见久久见中文字幕免费| 草b视频在线观看| 国产揄拍国内精品对白| 三上悠亚影音先锋| 狠狠色狠狠色综合日日小说| av中文字幕第一页| 日韩中文字幕在线看| 日本午夜精品久久久久| 欧美影视一区二区| 99亚洲视频| 欧美一级片黄色| 亚洲综合激情另类小说区| 91成人国产综合久久精品| 精品国产伦一区二区三区观看方式| 成人午夜在线影视| 国产一区二区在线免费| 奇米狠狠一区二区三区| 国产日韩一区二区在线观看| 成人av网址在线观看| 日韩黄色免费观看| 欧美一区二区三区喷汁尤物| 日本免费在线观看| 国产精品视频永久免费播放| 日本a口亚洲| 牛夜精品久久久久久久| 久久久综合九色合综国产精品| 69国产精品视频免费观看| 亚洲精品98久久久久久中文字幕| 亚洲妇熟xxxx妇色黄| 国产有码在线一区二区视频| 国产高清久久| 男女视频在线观看网站| 国产精品少妇自拍| 91麻豆视频在线观看| 日韩中文字幕精品| 九色porny丨国产首页在线| 黄色99视频| 久久激情视频| 日韩免费高清一区二区| 日韩欧美国产网站| 毛片在线免费| 国产在线观看精品一区二区三区| 欧美国产美女| www.久久com| 亚洲.国产.中文慕字在线| 日日夜夜精品免费| 欧美在线免费看| 亚洲成av人电影| 欧美午夜精品一区二区| 亚洲成av人片www| av中文字幕在线| 亚洲a一级视频| 中文字幕一区二区av | 清纯唯美激情亚洲| 久久男人资源站| 91浏览器在线视频| 一级黄色片免费| 欧美激情手机在线视频 | h片视频在线观看| 欧美激情专区| 久草精品在线观看| 日韩久久久久久久久| 亚洲男人天堂网站| 一区在线不卡| av免费中文字幕| 中文字幕视频一区二区三区久|