WEB前端技術(shù)核心:JaveScript學(xué)習(xí)之旅(繼承模式等小知識(shí)點(diǎn)剖析6)

? ? ? ? ? 原型繼承大概是javascript中古老又傳統(tǒng)的繼承方法了历涝,通過(guò)prototype兰迫,即可實(shí)現(xiàn)繼承薪缆,具體的用法我在之前的文章中也提到過(guò)秧廉。

? ? ? 所謂原型繼承就是利用javascript訪問(wèn)對(duì)象屬性或者方法時(shí)候會(huì)查找原型鏈這個(gè)特性,當(dāng)你創(chuàng)建父類(lèi)對(duì)象且實(shí)例賦值給子類(lèi)構(gòu)造函數(shù)的原型屬性拣帽,子類(lèi)的實(shí)例在創(chuàng)建時(shí)候都會(huì)通過(guò)__proto__查找然后與子類(lèi)構(gòu)造函數(shù).prototype的鏈接獲得父類(lèi)對(duì)象的所有屬性和方法疼电。這里要注意的是子類(lèi)對(duì)象只是從父類(lèi)繼承,這些屬性和方法并不真正的直接存在本身上减拭,而是存在其構(gòu)造函數(shù)的原型prototype對(duì)象中或者實(shí)例的__proto__屬性上蔽豺。

var Eat = function(){

? ? ? this.food = “面包”;

}拧粪;

var Person = function(){

? ? this.name = name修陡;

? ? this.action = function(){

? ? ? ? alert(“打完球感覺(jué)很餓,”+ “this.name” +“去商場(chǎng)買(mǎi)了”+ “this.food”)可霎;

}魄鸦;

Person.prototype = new Eat();

var person = new Person (“小明”)癣朗;

person.action()号杏;

輸出:打完球感覺(jué)很餓,小明去商場(chǎng)買(mǎi)了面包

當(dāng)Person實(shí)例person調(diào)用action()方法時(shí)候,需要找到this.food盾致,但是本身對(duì)象里沒(méi)有這個(gè)屬性,于是javascript就利用自身特性荣暮,沿著原型鏈查找庭惜,當(dāng)查找到person的構(gòu)造函數(shù)Person的prototype對(duì)象時(shí)候,發(fā)現(xiàn)了這一屬性并返回結(jié)果穗酥。

但是原型繼承并非完美的护赊,構(gòu)造函數(shù)的prototype在創(chuàng)建時(shí)候并非是完全的空對(duì)象,它里面是有一個(gè)屬性construcor砾跃,指的是它自己骏啰,如果用一個(gè)實(shí)例對(duì)象來(lái)替換函數(shù)的prototype,那這個(gè)屬性會(huì)被替換抽高,原本的constuctor屬性也隨之丟失判耕。

this.prototype ={construcor :this}

拿上面的例子來(lái)說(shuō):

輸出person的constructor:

function (){

? ? this.eat = “food”;

是Eat的構(gòu)造函數(shù)翘骂,Person的prototype會(huì)被Eat實(shí)例替換壁熄,那里面constructor屬性也被覆蓋。所以碳竟,如果需要保留真正的構(gòu)造器草丧,你可以在替換了Person的prototype之后再做些別的事情:

Person.prototype.constructor = Person;

這樣再訪問(wèn)person的constructor屬性時(shí)候會(huì)反回Person的構(gòu)造函數(shù)莹桅;

當(dāng)構(gòu)造器的prototype對(duì)象更新時(shí)候昌执,之前產(chǎn)生的所有實(shí)例對(duì)象也會(huì)做出立即更新:

var Eat = function(){

? ? ? this.food = “面包”;

}诈泼;

var Person = function(){

? ? this.name = name懂拾;

? ? this.action = function(){

? ? ? ? alert(“打完球感覺(jué)很渴+ “this.name” +“去商場(chǎng)喝了”+ “this.drinks);

}厂汗;

Person.prototype = new Eat()委粉;

var person = new Person (“小明”);

person.action()娶桦;

Person.prototype.drinks =“可樂(lè)”贾节;

person.action();

先后輸出:

打完球很渴衷畦,小明去商場(chǎng)喝了undefined

打完球很渴栗涂,小明去商場(chǎng)喝了可樂(lè)

很容易看出來(lái):

Person.prototype.drinks = “可樂(lè)”

作用等于

Eat.prototype.drinks = “可樂(lè)”

這僅僅是更新,而非把prototype換成別的對(duì)象祈争。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末斤程,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌忿墅,老刑警劉巖扁藕,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異疚脐,居然都是意外死亡亿柑,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)棍弄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)望薄,“玉大人,你說(shuō)我怎么就攤上這事呼畸『壑В” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵蛮原,是天一觀的道長(zhǎng)卧须。 經(jīng)常有香客問(wèn)我,道長(zhǎng)瞬痘,這世上最難降的妖魔是什么故慈? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮框全,結(jié)果婚禮上察绷,老公的妹妹穿的比我還像新娘。我一直安慰自己津辩,他們只是感情好拆撼,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著喘沿,像睡著了一般闸度。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蚜印,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天莺禁,我揣著相機(jī)與錄音,去河邊找鬼窄赋。 笑死哟冬,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的忆绰。 我是一名探鬼主播浩峡,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼错敢!你這毒婦竟也來(lái)了翰灾?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎纸淮,沒(méi)想到半個(gè)月后平斩,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡萎馅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年双戳,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片糜芳。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖魄衅,靈堂內(nèi)的尸體忽然破棺而出峭竣,到底是詐尸還是另有隱情,我是刑警寧澤晃虫,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布皆撩,位于F島的核電站,受9級(jí)特大地震影響哲银,放射性物質(zhì)發(fā)生泄漏扛吞。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一荆责、第九天 我趴在偏房一處隱蔽的房頂上張望滥比。 院中可真熱鬧,春花似錦做院、人聲如沸盲泛。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)寺滚。三九已至,卻和暖如春屈雄,著一層夾襖步出監(jiān)牢的瞬間村视,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工酒奶, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蚁孔,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓讥蟆,卻偏偏與公主長(zhǎng)得像勒虾,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子瘸彤,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

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