js中prototype屬性(原型方法)

js中prototype屬性(原型方法)

ID:14025449

大?。?0.00 KB

頁數(shù):9頁

時間:2018-07-25

js中prototype屬性(原型方法)_第1頁
js中prototype屬性(原型方法)_第2頁
js中prototype屬性(原型方法)_第3頁
js中prototype屬性(原型方法)_第4頁
js中prototype屬性(原型方法)_第5頁
資源描述:

《js中prototype屬性(原型方法)》由會員上傳分享,免費在線閱讀,更多相關(guān)內(nèi)容在行業(yè)資料-天天文庫。

1、js中prototype屬性(原型方法)JS中的prototype2011-06-0314:40by軒脈刃,12237閱讀,14評論,收藏,編輯JS中的phototype是JS中比較難理解的一個部分本文基于下面幾個知識點:1原型法設(shè)計模式在.Net中可以使用clone()來實現(xiàn)原型法原型法的主要思想是,現(xiàn)在有1個類A,我想要創(chuàng)建一個類B,這個類是以A為原型的,并且能進行擴展。我們稱B的原型為A。2javascript的方法可以分為三類:a類方法b對象方法c原型方法例子:functionPeople(name){this.name=name;//對象方

2、法this.Introduce=function(){alert("Mynameis"+this.name);}}//類方法People.Run=function(){alert("Icanrun");}//原型方法People.prototype.IntroduceChinese=function(){alert("我的名字是"+this.name);}//測試varp1=newPeople("Windking");p1.Introduce();People.Run();p1.IntroduceChinese();3obj1.func.call(o

3、bj)方法意思是將obj看成obj1,調(diào)用func方法好了,下面一個一個問題解決:prototype是什么含義?javascript中的每個對象都有prototype屬性,Javascript中對象的prototype屬性的解釋是:返回對象類型原型的引用。A.prototype=newB();理解prototype不應(yīng)把它和繼承混淆。A的prototype為B的一個實例,可以理解A將B中的方法和屬性全部克隆了一遍。A能使用B的方法和屬性。這里強調(diào)的是克隆而不是繼承。可以出現(xiàn)這種情況:A的prototype是B的實例,同時B的prototype也是A的

4、實例。先看一個實驗的例子:functionbaseClass(){this.showMsg=function(){alert("baseClass::showMsg");}}functionextendClass(){}extendClass.prototype=newbaseClass();varinstance=newextendClass();instance.showMsg();//顯示baseClass::showMsg我們首先定義了baseClass類,然后我們要定義extentClass,但是我們打算以baseClass的一個實例為原型

5、,來克隆的extendClass也同時包含showMsg這個對象方法。extendClass.prototype=newbaseClass()就可以閱讀為:extendClass是以baseClass的一個實例為原型克隆創(chuàng)建的。那么就會有一個問題,如果extendClass中本身包含有一個與baseClass的方法同名的方法會怎么樣?下面是擴展實驗2:functionbaseClass(){this.showMsg=function(){alert("baseClass::showMsg");}}functionextendClass(){this.

6、showMsg=function(){alert("extendClass::showMsg");}}extendClass.prototype=newbaseClass();varinstance=newextendClass();instance.showMsg();//顯示extendClass::showMsg實驗證明:函數(shù)運行時會先去本體的函數(shù)中去找,如果找到則運行,找不到則去prototype中尋找函數(shù)?;蛘呖梢岳斫鉃閜rototype不會克隆同名函數(shù)。那么又會有一個新的問題:如果我想使用extendClass的一個實例instance調(diào)

7、用baseClass的對象方法showMsg怎么辦?答案是可以使用call:extendClass.prototype=newbaseClass();varinstance=newextendClass();varbaseinstance=newbaseClass();baseinstance.showMsg.call(instance);//顯示baseClass::showMsg這里的baseinstance.showMsg.call(instance);閱讀為“將instance當做baseinstance來調(diào)用,調(diào)用它的對象方法showMsg

8、”好了,這里可能有人會問,為什么不用baseClass.showMsg.call(instance);這就是

當前文檔最多預(yù)覽五頁,下載文檔查看全文

此文檔下載收益歸作者所有

當前文檔最多預(yù)覽五頁,下載文檔查看全文
溫馨提示:
1. 部分包含數(shù)學公式或PPT動畫的文件,查看預(yù)覽時可能會顯示錯亂或異常,文件下載后無此問題,請放心下載。
2. 本文檔由用戶上傳,版權(quán)歸屬用戶,天天文庫負責整理代發(fā)布。如果您對本文檔版權(quán)有爭議請及時聯(lián)系客服。
3. 下載前請仔細閱讀文檔內(nèi)容,確認文檔內(nèi)容符合您的需求后進行下載,若出現(xiàn)內(nèi)容與標題不符可向本站投訴處理。
4. 下載文檔時可能由于網(wǎng)絡(luò)波動等原因無法下載或下載錯誤,付費完成后未能成功下載的用戶請聯(lián)系客服處理。