日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

深入理解 javaScript 原型繼承

瀏覽:18日期:2023-11-15 09:25:32
繼承的本質:重用

在探討 javaScript 的原型繼承之前,先不妨想想為什么要繼承?

考慮一個場景,如果我們有兩個對象,它們一部分屬性相同,另一部屬性不同。通常一個好的設計方案是將相同邏輯抽出來,實現重用。

以 xiaoMing liLei 兩位同學舉例。這兩位同學有自己的名字,并且會介紹自己。抽象為程序對象,可以做如下表示。

var xiaoMing = { name : 'xiaoMing', hello : function(){ console.log( ’Hello, my name is ’+ this.name + ’.’); }}var liLei = { name : 'liLei', hello : function(){ console.log( ’Hello, my name is ’+ this.name + ’.’); }}

使用過 java 的同學,可能第一眼就想到了用面向對象來解決這個問題。創造一個 Person 的類,然后實例化 xiaoMing 和 liLei 兩個對象。在 ES6 中也有類似于 java 中類的概念: class 。

下面使用 ES6 的語法,用面向對象的思路來重構上面的代碼。

class Person { constructor(name){ this.name = name } hello(){ console.log(this.name); }}var xiaoMing = new Person(’xiaoMing’);var liLei = new Person(’liLei’);

可以看到,使用類創建對象,達到了重用的目的。它基于的邏輯是,兩個或多個對象的結構功能類似,可以抽象出一個模板,依照模板復制出多個相似的對象。

使用類創建對象,就像自行車制造商一遍一遍地重用相同的藍圖來制造大量的自行車。

然解決重用問題的方案,當然不止一種。傳統面向對象的類,只是其中的一種方案。下面輪到我們的主角“原型繼承”登場了,它從另一個角度解決了重用的問題。

原型繼承的原理 原型對象

javaScript 中的 object 由兩部分組成,普通屬性的集合,和原型屬性。

var o = { a : ’a’, ... __proto__: prototypeObj}

普通屬性指的就是 a ; 原型屬性 指的是 __proto__ 。這本不屬于規范的一部分,后來 chrome 通過 __proto__ 將這個語言底層屬性給暴露出來了,慢慢的被大家所接受,也就添加到 ES6 規范中了。 o.__proto__ 的值 prototypeObj 也就是 原型對象 。原型對象其實也就是一個普通對象,之所以叫原型對象的原因,只是因為它是原型屬性所指的值。

原型對象所以特殊,是因為它擁有一個普通對象沒有的能力:將它的屬性共享給其他對象。

在 ES6 規范 中,對它是如下定義的:

object that provides shared properties for other objects 屬性讀操作

回到最開始的例子,看看如何利用原型繼承實現重用的目的。

var prototypeObj = { hello: function(){ console.log( ’Hello, my name is ’+ this.name + ’.’); } // ...}var xiaoMing = { name : 'xiaoMing', __proto__ : prototypeObj}var liLei = { name : 'liLei', __proto__ : prototypeObj}xiaoMing.hello(); // Hello, my name is xiaoMing.liLei.hello(); // Hello, my name is liLei.

xiaoMing liLei 對象上,并沒直接擁有 hello 屬性(方法),但是卻能讀取該屬性(執行該方法),這是為什么?

想象一個場景,你在做數學作業,遇到一個很難的題目,你不會做。而你有一個好兄弟,數學很厲害,你去請教他,把這道題做出來了。

xiaoMing 對象上,沒有 hello 屬性,但是它有一個好兄弟, prototypeObj 。屬性讀操作,在 xiaoMing 身上沒有找到 hello 屬性,就會去問它的兄弟 prototypeObj 。所以 hello 方法會被執行。

原型鏈

還是做數學題的例子。你的數學題目很難,你的兄弟也沒有答案,他推薦你去問另外一個同學。這樣直到有了答案或者再也沒有人可以問,你就不會再問下去。這樣就好像有一條無形鏈條把你和同學們牽在了一起。

在 JS 中,讀操作通過 __proto__ 會一層一層鏈下去的結構,就叫 原型鏈 。

var deepPrototypeObj = { hello: function(){ console.log( ’Hello, my name is ’+ this.name + ’.’); } __proto__ : null}var prototypeObj = { __proto__ : deepPrototypeObj}var xiaoMing = { name : 'xiaoMing', __proto__ : prototypeObj}var liLei = { name : 'liLei', __proto__ : prototypeObj}xiaoMing.hello(); // Hello, my name is xiaoMing.liLei.hello(); // Hello, my name is liLei. 原型繼承的實現

在上面的例子中,通過直接修改了 __proto__ 屬性值,實現了原型繼承。但是在實際生產中,

代替的方式是使用 Object.create() 方法。

調用 Object.create() 方法會創建一個新對象,同時指定該對象的原型對象為傳入的第一個參數。

我們將上面的例子改一下。

var prototypeObj = { hello: function(){ console.log( ’Hello, my name is ’+ this.name + ’.’); } // ...}var xiaoMing = Object.create(prototypeObj);var liLei = Object.create(prototypeObj);xiaoMing.name = 'xiaoMing';liLei.name = 'liLei';xiaoMing.hello(); // Hello, my name is xiaoMing.liLei.hello(); // Hello, my name is liLei.

You-Dont-Know-JS 的作者,對這種原型繼承的實現取了一個很好玩的名字 OLOO (objects-linked-to-other-objects) ,這種實現方式的優點是沒有使用任何類的概念,只有 object ,所以它是很符合 javaScript 的特性的。

因為JS 中本無類,只有 object 。

無奈的是,喜歡類的程序員是在太多,所以在 ES6 新增了 class 概念。下一篇會講 class 在 JS 中的實現原理

小結

類創建對象,達到了重用的目的。它基于的邏輯是,兩個或多個對象的結構功能類似,可以抽象出一個模板,依照模板 復制 出多個相似的對象。就像自行車制造商一遍一遍地重用相同的藍圖來制造大量的自行車。

使用原型繼承,同樣可以達到重用的目的。它基于的邏輯是,兩個或多個對象的對象有一部分共用屬性,可以將共用的屬性抽象到另一個獨立公共對象上,通過特殊的原型屬性,將公共對象和普通對象鏈接起來,再利用屬性讀(寫)規則進行遍歷查找,實現屬性 共享 。

來自:https://segmentfault.com/a/1190000008293372

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
99久久亚洲精品蜜臀| 日韩精品视频中文字幕| 亚洲日本免费电影| 中文字幕高清在线播放| 精品国产一级| 日韩精品福利一区二区三区| 红桃视频国产精品| 爽好多水快深点欧美视频| 国产视频亚洲| 免费人成在线不卡| 免费久久精品视频| 日韩中文在线电影| 亚洲欧洲一区| 亚洲精品99| 国产午夜精品一区二区三区欧美| 日韩中文字幕区一区有砖一区 | 国产精品对白| 欧美日韩在线精品一区二区三区激情综合 | 亚洲精品无吗| 麻豆成人在线| 亚洲专区视频| 综合一区av| 国产精品中文字幕制服诱惑| 国产欧美一区二区三区国产幕精品| 日本在线成人| 激情国产在线| 日韩精品91| 亚洲特色特黄| 亚洲日本欧美| 美女国产精品久久久| 黑人精品一区| 亚洲欧美日韩高清在线| 五月天久久网站| 日韩精品一级二级| 婷婷久久一区| 欧美日韩a区| 亚洲成人精品| 99久久精品费精品国产| 亚洲在线成人| 国产乱人伦精品一区| 日韩在线短视频| 国产欧美日韩精品高清二区综合区| 在线看片国产福利你懂的| 日本在线不卡视频一二三区| 久久不卡日韩美女| 亚洲欧美激情诱惑| 亚洲美女久久精品| 日韩在线观看一区二区三区| 日韩不卡一区二区| 国产66精品| 亚洲免费一区二区| 天堂av在线| 日韩精品电影一区亚洲| 亚洲大片在线| 国产精品天天看天天狠| 欧美不卡高清| 婷婷激情一区| 国产精品久久久亚洲一区| 亚洲区第一页| aa亚洲婷婷| 91综合视频| 国产精品igao视频网网址不卡日韩| 日韩精品不卡一区二区| 开心激情综合| 美国三级日本三级久久99| 欧美成人午夜| 欧美不卡高清一区二区三区| 美女国产一区二区三区| 欧美日韩黄网站| 亚洲一区二区三区中文字幕在线观看| 欧美日韩精品一区二区视频| 欧美a级一区二区| 久久精品国产亚洲一区二区三区| 国产欧美一区二区三区米奇| 国产美女精品视频免费播放软件| 国产欧美日韩精品一区二区三区| 欧美日韩夜夜| 国产一区二区三区不卡av | 日韩精品第一| 欧美在线看片| 精品国产黄a∨片高清在线| 免费在线亚洲欧美| 老牛影视精品| 蜜桃视频欧美| 夜夜嗨av一区二区三区网站四季av| 久久久国产精品一区二区中文| 欧美69视频| 深夜福利一区| 国产精品中文字幕亚洲欧美| 久久三级中文| 蜜桃视频欧美| 欧美亚洲色图校园春色| 日本午夜精品| 国产va免费精品观看精品视频| 国产传媒在线观看| 久久激情婷婷| 国产另类在线| 久久亚洲资源中文字| 中文久久精品| 国产精品亚洲产品| 欧美成人a交片免费看| 日韩精品一区第一页| 国产精品综合| 亚洲精品**中文毛片| 九色精品91| 欧美交a欧美精品喷水| 四虎884aa成人精品最新| av在线日韩| 国产精品一区二区三区www| 美女网站一区| 久久精品三级| 亚洲综合另类| 日韩成人免费| 日韩精品成人在线观看| 精品国产精品国产偷麻豆| 亚洲专区欧美专区| 日本免费新一区视频| 99久久激情| 国产日韩一区二区三免费高清 | 少妇精品在线| www.九色在线| 蜜桃久久av一区| 欧洲一区二区三区精品| 国产日韩一区二区三免费高清| 激情综合亚洲| 99精品小视频| 久久麻豆视频| 国产精品99久久久久久董美香| 日韩欧美1区| 国产亚洲第一伦理第一区| 久久久久亚洲| 欧美特黄一级大片| 精品一区二区三区的国产在线观看 | 四虎在线精品| 亚洲一区二区三区高清| 精品国产麻豆| 一区二区精彩视频| 免费毛片在线不卡| 亚洲午夜av| 久久久久网站| 久久久久久久久久久9不雅视频| 精品日韩一区| 国产精品久久久免费| 88久久精品| 麻豆国产欧美一区二区三区 | 欧洲在线一区| 国产中文在线播放| 久久免费高清| 免费在线观看精品| 青青草视频一区| xxxxx性欧美特大| 久久性天堂网| 日韩精品视频一区二区三区| 日韩一区二区三免费高清在线观看| 91精品推荐| 久久精品一区二区不卡| 日韩欧美一区二区三区在线视频| 特黄毛片在线观看| 夜鲁夜鲁夜鲁视频在线播放| 日韩精品三级| 国产精品99免费看| 免费精品国产的网站免费观看| 亚洲精品在线观看91| 天堂av在线一区| 怡红院精品视频在线观看极品| 伊人久久大香线蕉av不卡| 精品视频一区二区三区在线观看| 日产午夜精品一线二线三线| 鲁鲁在线中文| 亚洲精品午夜av福利久久蜜桃| 麻豆精品一区二区综合av| 国产香蕉精品| 国产精品久久久久av蜜臀| 99在线|亚洲一区二区| 成人精品中文字幕| 色老板在线视频一区二区| 国产日韩综合| 成人日韩av| 欧美日韩一区二区综合| 性欧美69xoxoxoxo| 91精品一区二区三区综合在线爱 | 丁香婷婷久久| 国产亚洲欧洲| 国产精品777777在线播放| 精品国产美女a久久9999| 六月婷婷一区| 日韩中文字幕在线一区| 亚洲毛片在线免费| 成人一区而且| 国产在线日韩| 国产日韩1区| 在线视频亚洲| 久久不卡国产精品一区二区| 欧洲av不卡| 欧美在线黄色| 国内精品伊人| 喷白浆一区二区| 免费日韩一区二区三区| 91精品蜜臀一区二区三区在线| 亚洲精品麻豆|