對(duì)原型與原型鏈的理解

最開始想要直觀的理解請(qǐng)直接參考阮一峰老師博客關(guān)于繼承的講解:http://www.ruanyifeng.com/blog/2011/06/designing_ideas_of_inheritance_mechanism_in_javascript.html

原型對(duì)象

javascript語言是一種面向?qū)ο蟮恼Z言饮六,它沒有"子類"和"父類"的概念嫡良,里面所有的數(shù)據(jù)類型都是對(duì)象,如何將這些對(duì)象聯(lián)系起來呢?

Brendan Eich在考慮設(shè)計(jì)繼承機(jī)制的時(shí)候哩牍,參考了C++和JAVA使用new命令,通過調(diào)用類的構(gòu)造函數(shù)生成實(shí)例的方式,將new命令引入javascript。

C++的寫法是:

ClassName *object = new ClassName(param);

Java的寫法是:

Person person = new Person();

但是乱灵,javascript里面沒有“類”這個(gè)概念,那么七冲,Brendan Eich決定直接在new后面跟一個(gè)構(gòu)造函數(shù)痛倚,來生成實(shí)例。

構(gòu)造函數(shù)是什么澜躺?構(gòu)造函數(shù)與其他函數(shù)唯一的區(qū)別在于調(diào)用方式不同蝉稳。任何函數(shù)只要通過new來調(diào)用就可以作為構(gòu)造函數(shù),它是用來創(chuàng)建特定類型的對(duì)象掘鄙。

下面定義一個(gè)構(gòu)造函數(shù)Female:

 function Female(name){
 this.name = name;
 this.sex = 'female';  
}

通過new命令來生成一個(gè)person實(shí)例:

var person1 = new Female("Summer")

這里耘戚,構(gòu)造函數(shù)Female就是實(shí)例對(duì)象person1的原型!2倌收津!Female里的this關(guān)鍵字就指的是person1這個(gè)對(duì)象!

new出來的person1對(duì)象此時(shí)已經(jīng)和Female再無聯(lián)系了浊伙!也就是說每一個(gè)new出來的實(shí)例都有自己的屬性和方法的副本撞秋,是獨(dú)立的的!修改其中一個(gè)不會(huì)影響另一個(gè)嚣鄙!

var person1 = new Female("Summer");
var person2 = new Female("Lily");

person2.sex = 'male';

console.log(person1.sex)      // female
console.log(person2.sex)      // male

但是吻贿,我們希望構(gòu)造函數(shù)中的sex屬性是一個(gè)共有屬性,那么此時(shí)用這樣的方法拗慨,每個(gè)實(shí)例中都有一個(gè)相同的sex屬性廓八,會(huì)造成資源極大的浪費(fèi)奉芦!

那么原型對(duì)象就即將登場(chǎng)了赵抢!Brendan Eich決定給每一個(gè)構(gòu)造函數(shù)都設(shè)置一個(gè)prototype屬性,這個(gè)屬性就指向原型對(duì)象声功。其實(shí)原型對(duì)象就只是個(gè)普通對(duì)象烦却,里面存放著所有實(shí)例對(duì)象需要共享的屬性和方法!所以先巴,我們把需要共享的放到原型對(duì)象里其爵,把那些不需要共享的屬性和方法存在在構(gòu)造函數(shù)里!

那么上面的代碼可改寫如下:

    function Person(name,age){ this.name = name;
    }
    Person.prototype.sex = 'female';
    var person1 = new Person("Summer"); 
    var person2 = new Person("Lily");

    console.log(person1.sex) // female
    console.log(person2.sex)      // female
   Person.prototype.sex = 'male';

    console.log(person1.sex) // male
    console.log(person2.sex)      // male</pre>

可以看出伸蚯,修改prototype屬性會(huì)影響它的所有實(shí)例的sex的值Dγ臁!

實(shí)例一旦創(chuàng)建出來就會(huì)自動(dòng)引用prototype對(duì)象的屬性和方法剂邮!所以實(shí)例對(duì)象的屬性和方法一般分為兩種:一種是自身的摇幻,一種是引用自prototype的。

具體實(shí)現(xiàn)是這樣的:

每當(dāng)代碼讀取某個(gè)對(duì)象的某個(gè)屬性的時(shí)候,都會(huì)執(zhí)行一次搜索绰姻。首先從對(duì)象實(shí)例本身開始枉侧,如果在實(shí)例中找到了該屬性,則返回該屬性的值狂芋,如果沒有找到榨馁,則順著原型鏈指針向上,到原型對(duì)象中去找帜矾,如果如果找到就返回該屬性值翼虫。

這里要提一點(diǎn),如果為對(duì)象實(shí)例添加了一個(gè)屬性與原型中同名黍特,則該屬性會(huì)屏蔽掉原型中的同名屬性蛙讥,不會(huì)去修改它!使用delete可以刪除實(shí)例中的屬性(提到delete那要插一句delete只能刪除對(duì)象下的屬性灭衷,不能刪除變量和參數(shù)次慢!)

原型鏈

事實(shí)上,js里完全依靠"原型鏈"(prototype chain)模式來實(shí)現(xiàn)繼承翔曲。

上面說完原型對(duì)象迫像。下面要扒一扒proto、prototype瞳遍、constructor

proto:事實(shí)上就是原型鏈指針N偶恕!

prototype:上面說到這個(gè)是指向原型對(duì)象的

constructor:每一個(gè)原型對(duì)象都包含一個(gè)指向構(gòu)造函數(shù)的指針掠械,就是constructor

繼承實(shí)現(xiàn)方式:

為了實(shí)現(xiàn)繼承由缆,proto會(huì)指向上一層的原型對(duì)象,而上一層的結(jié)構(gòu)依然類似猾蒂,那么就利用proto一直指向Object的原型對(duì)象上均唉!Object.prototype.proto = null;表示到達(dá)最頂端。如此形成了原型鏈繼承肚菠。

下面有個(gè)圖解非常經(jīng)典舔箭,我自己也手畫了一遍去理解,真的非常有效~

image

大致總結(jié)一下就是:

Object是作為眾多new出來的實(shí)例的基類 function Object(){ [ native code ] }

Function是作為眾多function出來的函數(shù)的基類 function Function(){ [ native code ] }

構(gòu)造函數(shù)的proto(包括Function.prototype和Object.prototype)都指向Function.prototype

原型對(duì)象的proto都指向Object.prototype

Object.prototype.proto指向null
轉(zhuǎn)自【http://www.cnblogs.com/ningyn0712/p/6216711.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末蚊逢,一起剝皮案震驚了整個(gè)濱河市层扶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌烙荷,老刑警劉巖镜会,帶你破解...
    沈念sama閱讀 217,509評(píng)論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異终抽,居然都是意外死亡戳表,警方通過查閱死者的電腦和手機(jī)焰薄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來扒袖,“玉大人塞茅,你說我怎么就攤上這事〖韭剩” “怎么了野瘦?”我有些...
    開封第一講書人閱讀 163,875評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長飒泻。 經(jīng)常有香客問我鞭光,道長,這世上最難降的妖魔是什么泞遗? 我笑而不...
    開封第一講書人閱讀 58,441評(píng)論 1 293
  • 正文 為了忘掉前任惰许,我火速辦了婚禮,結(jié)果婚禮上史辙,老公的妹妹穿的比我還像新娘汹买。我一直安慰自己,他們只是感情好聊倔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,488評(píng)論 6 392
  • 文/花漫 我一把揭開白布晦毙。 她就那樣靜靜地躺著,像睡著了一般耙蔑。 火紅的嫁衣襯著肌膚如雪见妒。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,365評(píng)論 1 302
  • 那天甸陌,我揣著相機(jī)與錄音须揣,去河邊找鬼。 笑死钱豁,一個(gè)胖子當(dāng)著我的面吹牛耻卡,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播寥院,決...
    沈念sama閱讀 40,190評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼劲赠,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼涛目!你這毒婦竟也來了秸谢?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤霹肝,失蹤者是張志新(化名)和其女友劉穎估蹄,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沫换,經(jīng)...
    沈念sama閱讀 45,500評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡臭蚁,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,706評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片垮兑。...
    茶點(diǎn)故事閱讀 39,834評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡冷尉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出系枪,到底是詐尸還是另有隱情雀哨,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評(píng)論 5 345
  • 正文 年R本政府宣布私爷,位于F島的核電站雾棺,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏衬浑。R本人自食惡果不足惜捌浩,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,167評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望工秩。 院中可真熱鬧尸饺,春花似錦、人聲如沸助币。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽奠支。三九已至馋辈,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間倍谜,已是汗流浹背迈螟。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留尔崔,地道東北人答毫。 一個(gè)月前我還...
    沈念sama閱讀 47,958評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像季春,于是被迫代替她去往敵國和親洗搂。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,779評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容