亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > JavaScript > 正文

JS中prototype的用法實例分析

2024-05-06 16:17:16
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了JS中prototype的用法,實例分析了JS中prototype的常見使用技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了JS中prototype的用法。分享給大家供大家參考。具體分析如下:

JS中的phototype是JS中比較難理解的一個部分

本文基于下面幾個知識點:

1 原型法設計模式

在.Net中可以使用clone()來實現原型法

原型法的主要思想是,現在有1個類A,我想要創建一個類B,這個類是以A為原型的,并且能進行擴展。我們稱B的原型為A。

2 javascript的方法可以分為三類:

a 類方法

b 對象方法

c 原型方法

例子如下:

 

 
  1. function People(name) 
  2. this.name=name; 
  3. //對象方法 
  4. this.Introduce=function(){ 
  5. alert("My name is "+this.name); 
  6. //類方法 
  7. People.Run=function(){ 
  8. alert("I can run"); 
  9. //原型方法 
  10. People.prototype.IntroduceChinese=function(){ 
  11. alert("我的名字是"+this.name); 
  12. //測試 
  13. var p1=new People("Windking"); 
  14. p1.Introduce(); 
  15. People.Run(); 
  16. p1.IntroduceChinese(); 

3 obj1.func.call(obj)方法

意思是將obj看成obj1,調用func方法

好了,下面一個一個問題解決:

prototype是什么含義?

javascript中的每個對象都有prototype屬性,Javascript中對象的prototype屬性的解釋是:返回對象類型原型的引用。

 

 
  1. A.prototype = new B(); 
 

 

 

理解prototype不應把它和繼承混淆。A的prototype為B的一個實例,可以理解A將B中的方法和屬性全部克隆了一遍。A能使用B的方法和屬性。這里強調的是克隆而不是繼承??梢猿霈F這種情況:A的prototype是B的實例,同時B的prototype也是A的實例。

先看一個實驗的例子:

 

  1. function baseClass() 
  2. this.showMsg = function() 
  3. alert("baseClass::showMsg");  
  4. function extendClass() 
  5. extendClass.prototype = new baseClass(); 
  6. var instance = new extendClass(); 
  7. instance.showMsg(); // 顯示baseClass::showMsg 


我們首先定義了baseClass類,然后我們要定義extentClass,但是我們打算以baseClass的一個實例為原型,來克隆的extendClass也同時包含showMsg這個對象方法。

extendClass.prototype = new baseClass()就可以閱讀為:extendClass是以baseClass的一個實例為原型克隆創建的。

那么就會有一個問題,如果extendClass中本身包含有一個與baseClass的方法同名的方法會怎么樣?

下面是擴展實驗2:

 

 
  1. function baseClass() 
  2. this.showMsg = function() 
  3. alert("baseClass::showMsg");  
  4. function extendClass() 
  5. this.showMsg =function () 
  6. alert("extendClass::showMsg"); 
  7. extendClass.prototype = new baseClass(); 
  8. var instance = new extendClass(); 
  9. instance.showMsg();//顯示extendClass::showMsg 

實驗證明:函數運行時會先去本體的函數中去找,如果找到則運行,找不到則去prototype中尋找函數?;蛘呖梢岳斫鉃閜rototype不會克隆同名函數。

那么又會有一個新的問題:

如果我想使用extendClass的一個實例instance調用baseClass的對象方法showMsg怎么辦?

答案是可以使用call:

 

 
  1. extendClass.prototype = new baseClass(); 
  2. var instance = new extendClass(); 
  3. var baseinstance = new baseClass(); 
  4. baseinstance.showMsg.call(instance);//顯示baseClass::showMsg 

這里的baseinstance.showMsg.call(instance);閱讀為“將instance當做baseinstance來調用,調用它的對象方法showMsg”

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

這就是對象方法和類方法的區別,我們想調用的是baseClass的對象方法

最后,下面這個代碼如果理解清晰,那么這篇文章說的就已經理解了:

 

 
  1. <script type="text/javascript"
  2. function baseClass() 
  3. this.showMsg = function() 
  4. alert("baseClass::showMsg");  
  5. this.baseShowMsg = function() 
  6. alert("baseClass::baseShowMsg"); 
  7. baseClass.showMsg = function() 
  8. alert("baseClass::showMsg static"); 
  9. function extendClass() 
  10. this.showMsg =function () 
  11. alert("extendClass::showMsg"); 
  12. extendClass.showMsg = function() 
  13. alert("extendClass::showMsg static"
  14. extendClass.prototype = new baseClass(); 
  15. var instance = new extendClass(); 
  16. instance.showMsg(); //顯示extendClass::showMsg 
  17. instance.baseShowMsg(); //顯示baseClass::baseShowMsg 
  18. instance.showMsg(); //顯示extendClass::showMsg 
  19. baseClass.showMsg.call(instance);//顯示baseClass::showMsg static 
  20. var baseinstance = new baseClass(); 
  21. baseinstance.showMsg.call(instance);//顯示baseClass::showMsg 
  22. </script> 

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品久久久久久久久粉嫩av| 国产成人精品久久久| 91免费欧美精品| 亚洲天堂视频在线观看| 国产亚洲欧美一区| 亚洲成年网站在线观看| 奇米影视亚洲狠狠色| 亚洲人免费视频| 日韩va亚洲va欧洲va国产| 久久久电影免费观看完整版| 日韩高清电影好看的电视剧电影| 91爱爱小视频k| 久久免费少妇高潮久久精品99| 亚洲一区二区少妇| 亚洲free性xxxx护士白浆| 欧美日韩国产一区在线| 亚洲男人av电影| 欧美成人免费大片| 69久久夜色精品国产7777| 麻豆成人在线看| 91亚洲精品久久久久久久久久久久| 97精品一区二区视频在线观看| 欧美乱大交xxxxx另类电影| 91影院在线免费观看视频| 日韩国产高清视频在线| 91久久精品国产91久久| 国产在线精品一区免费香蕉| 91精品国产高清自在线看超| 亚洲美女www午夜| 日韩欧美在线播放| 久久精品夜夜夜夜夜久久| 日本中文字幕不卡免费| 中文字幕亚洲一区二区三区| 日韩黄色高清视频| 日韩视频第一页| 欧美日韩亚洲网| 高清日韩电视剧大全免费播放在线观看| 亚洲一品av免费观看| 亚洲国产成人av在线| 538国产精品一区二区在线| 国产精品香蕉av| 国产69精品久久久久久| 欧美精品亚州精品| 精品久久久久久久久久久久久久| 欧美亚洲午夜视频在线观看| 成人黄色av网| 97视频免费观看| 国产亚洲一区二区在线| 久久免费视频网| 国产不卡av在线免费观看| 亚洲人成电影在线观看天堂色| 不卡中文字幕av| 国产精品专区h在线观看| 国产一区玩具在线观看| 亚洲精品国产精品乱码不99按摩| 国产丝袜高跟一区| 亚洲国产天堂久久国产91| 亚洲自拍av在线| 欧美精品做受xxx性少妇| 欧美激情极品视频| 欧美激情亚洲一区| 亚洲va男人天堂| 性欧美长视频免费观看不卡| 91精品国产乱码久久久久久蜜臀| 国产精品久久网| 亚洲天堂免费观看| 国产视频自拍一区| 亚洲精品成人久久| 欧美性jizz18性欧美| 久久精品国产99国产精品澳门| 久久成人亚洲精品| 日韩麻豆第一页| 九色精品免费永久在线| 欧美乱大交做爰xxxⅹ性3| 久久综合国产精品台湾中文娱乐网| 国产亚洲欧美aaaa| 日韩一区二区福利| 国产欧美欧洲在线观看| 91免费综合在线| 国产精品国产三级国产aⅴ浪潮| 成人黄色av免费在线观看| 欧美综合国产精品久久丁香| 久久久久久亚洲精品中文字幕| 91麻豆桃色免费看| 91精品国产综合久久久久久久久| 久久久久久亚洲精品中文字幕| 亚洲欧洲在线观看| 91天堂在线视频| 亚洲精品永久免费| 欧美日韩一区二区免费在线观看| 日韩精品中文字幕视频在线| 中文字幕一区电影| 欧美日韩亚洲网| 亚洲精品suv精品一区二区| 97人洗澡人人免费公开视频碰碰碰| 亚洲欧美日韩爽爽影院| 亚洲少妇激情视频| 国产成人精品综合久久久| 久久精视频免费在线久久完整在线看| 日韩高清不卡av| 有码中文亚洲精品| 国产欧美韩国高清| 成人在线视频福利| 成人午夜高潮视频| 韩国国内大量揄拍精品视频| 国产成人97精品免费看片| 91精品国产高清久久久久久久久| 国产精品观看在线亚洲人成网| 日韩欧美一区二区三区久久| 人人澡人人澡人人看欧美| 中文字幕精品在线视频| 久久久欧美一区二区| 欧美精品videossex88| 成人黄色短视频在线观看| 日本久久中文字幕| 亚洲国产精品一区二区久| 秋霞av国产精品一区| xxav国产精品美女主播| 国产精品1234| 亚洲精品国产精品久久清纯直播| 91精品国产综合久久香蕉922| 欧美极品第一页| 国产成人精品日本亚洲专区61| y97精品国产97久久久久久| 亚洲综合在线中文字幕| 亚洲色在线视频| 国产综合久久久久| 日韩在线激情视频| 久久激情视频久久| 少妇精69xxtheporn| 日韩精品在线免费观看视频| 久久久久久成人精品| 精品久久久中文| 亚洲欧美日韩一区二区在线| www.xxxx欧美| 91九色单男在线观看| 亚洲福利视频二区| 亚洲第一精品夜夜躁人人躁| 国产又爽又黄的激情精品视频| 97人人爽人人喊人人模波多| 在线观看国产精品日韩av| 国产91在线高潮白浆在线观看| 日韩免费在线视频| 国产精品久久久久av| 红桃视频成人在线观看| 成年人精品视频| 久久精品国产综合| 日韩精品视频在线播放| 亚洲男人av在线| 亚洲综合中文字幕在线| 日本最新高清不卡中文字幕| 国产精品日本精品| 亚洲黄在线观看| 午夜精品国产精品大乳美女| 精品电影在线观看| 亚洲高清一二三区| 国产精品免费久久久| 日韩专区中文字幕| 亚洲免费人成在线视频观看| 欧美人交a欧美精品| 欧美激情一区二区久久久| 午夜精品www| 亚洲另类欧美自拍| 国产精自产拍久久久久久|