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

首頁 > 開發 > JS > 正文

JS利用prototype給類添加方法操作詳解

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

本文實例講述了JS利用prototype給類添加方法操作。分享給大家供大家參考,具體如下:

1.如何定義一個簡單的類?

以下是一個沒有任何屬性和方法的類的定義:

function MyClass(){};

你可能會想,這不就是個簡單的函數聲明?沒錯,這個函數就是一個類的定義的實現。如何使用這個類呢?看下面的代碼:

var cls1 = new MyClass();

這樣,利用new就可以生成MyClass的一個實例了。所以在js中可以說函數就是類,類就是函數。

2.給類增加屬性和方法

function MyClass(name,age){  this.name = name;  this.age = age;}var cls1 = new MyClass("lily",18);alert(cls1.name);

從上面的代碼可以看出,在函數內使用this就能給函數本身增加屬性值。而在上面的代碼中就給myClass函數增加了name和age屬性。

同樣,還可以利用this給這個類增加一個 toString 方法,代碼如下:

function MyClass(name,age){  this.name = name;  this.age = age;  this.toString() = function(){    alert(this.name +":"+ this.age);  };}var cls1 = new MyClass("liming",10);cls1.toString();

我們已經成功的給MyClass增加了toString方法。另外也可以用以下代碼來添加方法:

function MyClass(name,age){  this.name = name;  this.age = age;}var cls1 = new MyClass("liming",10);cls1.toString() = function(){            alert(this.name +":"+ this.age);          };cls1.toString(); // [liming:10]var cls2 = new MyClass("zhang",10);cls2.toString(); //報錯

雖然這樣也能給這個類添加一個方法,但這種方式只是給cls1這個實例增加了方法,并未給MyClass本身增加方法。

cls2并不存在toString方法。

3.引出prototype

從上面我們已經知道要給MyClss類的本身增加方法,需要講方法定義在MyClass這個函數內部,這樣的話,每聲明一個新的實例,就會將MyClass本身復制一遍,這顯然不是最優的做法。

既然不能將一個類(函數)所包含的方法都定義在函數的內部,那么,如何來給一個類添加方法呢?這就需要用到函數的prototype屬性了。

每一個函數都會包含一個prototype屬性,這個屬性指向了一個prototype對象,我們可以指定函數對應的prototype對象。如果不指定,則函數的prototype屬性將指向一個默認的prototype對象,并且次默認的prototype對象的constructor屬性又會指向該函數。

當用構造函數創建一個新的對象時,新的對象會獲取構造函數的prototype屬性所指向的prototype對象的所有屬性和方法,這樣一來,構造函數對應的prototype對象所做的任何操作都會反映到它所生成的對象上,所有的這些對象將共享與構造函數對應的prototype對象的屬性和方法。

雖然新創建的對象可以使用它的構造函數所指向的prototype對象的屬性和方法,但不能像構造函數那樣直接調用prototype對象(對象沒有prototype屬性)。

簡而言之,就是如果我們使用函數的prototype對象來給函數添加方法,那么在創建一個新的對象的時候,并不會復制這個函數的所有方法,而是指向了這函數的所有方法。

具體看下面的代碼:

function MyClass(name,age){  this.name = name;  this.age = age;}MyClass.prototype.toString = function(){  //}var cls1 = new MyClass("liming",10);cls1.toString(); //var cls2 = new MyClass("zhang",10);cls2.toString();

如果要加入多個方法,也可以使用下面的方式:

function MyClass(name,age){  this.name = name;  this.age = age;}MyClass.prototype = {  toString:function(){    //  },  sayHellow:function(){    //  }};

這就是js中給類添加方法的實現,它是利用prototype來實現封裝的。

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


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成人午夜高潮视频| 美女国内精品自产拍在线播放| 精品自在线视频| 久久久人成影片一区二区三区| 国产精品女主播| 久久露脸国产精品| 久久久久久网站| 91av在线看| 国产精品嫩草视频| 国产+人+亚洲| 国产日韩视频在线观看| 国产精品视频不卡| 欧美一级视频在线观看| 欧美在线激情视频| 欧美一级电影在线| 亚洲网站视频福利| 国产精品视频区1| 91亚洲午夜在线| 久久精品国产2020观看福利| 国内揄拍国内精品少妇国语| 精品色蜜蜜精品视频在线观看| 欧美激情成人在线视频| 亚洲精品福利免费在线观看| 久久精品国产亚洲7777| 日本高清久久天堂| 91中文在线观看| 亚洲一区二区久久| 日本韩国欧美精品大片卡二| 亚洲欧美成人在线| 国产91网红主播在线观看| 社区色欧美激情 | 午夜精品久久久久久久久久久久| 色悠久久久久综合先锋影音下载| 在线精品视频视频中文字幕| 成人观看高清在线观看免费| 中文在线资源观看视频网站免费不卡| 川上优av一区二区线观看| 粗暴蹂躏中文一区二区三区| 国产精品久久久久一区二区| 69影院欧美专区视频| 亚洲一品av免费观看| 欧美—级a级欧美特级ar全黄| 久久久久久久久亚洲| 日韩av在线天堂网| 福利一区视频在线观看| 欧美精品在线观看| 精品国产一区二区三区久久久| 亚洲色图美腿丝袜| 国产一区香蕉久久| 国产精品视频精品视频| 亚洲国产成人久久综合| 成人av资源在线播放| 深夜福利亚洲导航| 欧洲成人午夜免费大片| 国产精品一区二区久久| 97国产真实伦对白精彩视频8| 91免费国产网站| 欧美最近摘花xxxx摘花| 成人免费看片视频| 精品久久久久久久久久久久久| 欧美色道久久88综合亚洲精品| 欧美国产日韩免费| 日韩中文在线中文网三级| 亚洲第一av网站| 国产精品日韩av| 欧美激情一区二区三区高清视频| 一区三区二区视频| 日韩av电影免费观看高清| 亚洲黄色片网站| 亚洲精品久久在线| 久久亚洲精品网站| 欧美一区二区三区免费观看| 日韩视频在线一区| 亚洲爱爱爱爱爱| 日韩精品视频在线观看免费| 国模吧一区二区三区| 欧美亚洲在线播放| 国产精品免费福利| 精品国产乱码久久久久久虫虫漫画| 69久久夜色精品国产69| 91沈先生在线观看| 久久久中精品2020中文| 亚洲电影免费观看高清| 国产99久久精品一区二区 夜夜躁日日躁| 午夜精品久久久久久久久久久久久| 欧美大奶子在线| 欧美大全免费观看电视剧大泉洋| 国产ts人妖一区二区三区| 欧美激情亚洲视频| 欧美国产精品人人做人人爱| 亚洲精品自拍视频| 欧美午夜宅男影院在线观看| 91精品久久久久久久久久久久久久| 亚洲欧美日韩成人| 92国产精品视频| 欧美国产激情18| 欧美专区国产专区| 一区二区三区天堂av| 国产亚洲一区精品| 国产成人精品最新| 日韩av第一页| 91精品啪aⅴ在线观看国产| 亚洲精品少妇网址| 九九热99久久久国产盗摄| 国产91精品久久久| 日韩69视频在线观看| 97精品视频在线观看| 欧美在线视频免费| 91精品国产自产在线| 精品福利在线视频| 亚洲精品美女在线| 欧美性xxxxx| 亚洲精品电影网站| 亚洲精品视频二区| 91视频免费网站| 日韩国产一区三区| 久久夜色精品国产亚洲aⅴ| 日韩欧美一区二区三区久久| 精品福利视频导航| 日韩中文有码在线视频| 欧美日本中文字幕| 精品久久久久久亚洲国产300| 精品国产鲁一鲁一区二区张丽| 日韩一区二区精品视频| 亚洲国产欧美一区二区三区同亚洲| 综合av色偷偷网| 精品国产鲁一鲁一区二区张丽| www.日韩.com| 欧美性色19p| 日韩在线播放一区| 国产经典一区二区| 欧美三级欧美成人高清www| 亚洲欧美一区二区三区情侣bbw| 国产美女高潮久久白浆| 国语自产精品视频在线看抢先版图片| 日韩精品视频免费在线观看| 亚洲免费视频观看| 久久精品国产久精国产一老狼| 亚洲香蕉伊综合在人在线视看| 久久精品91久久香蕉加勒比| 九九热最新视频//这里只有精品| 国产精品爱久久久久久久| 久久久亚洲精品视频| 精品视频中文字幕| 亚洲伊人成综合成人网| 成人羞羞国产免费| 国产女精品视频网站免费| 国产一区玩具在线观看| 久久精品一本久久99精品| 欧美三级欧美成人高清www| 欧美性少妇18aaaa视频| 91欧美视频网站| 丝袜情趣国产精品| 亚洲欧洲日本专区| 另类天堂视频在线观看| 成人性生交大片免费看视频直播| 欧美激情综合亚洲一二区| 亚洲乱码国产乱码精品精天堂| 欧美国产欧美亚洲国产日韩mv天天看完整| 亚洲人成电影网站色| 欧美另类老肥妇| 欧美激情第一页xxx| 日韩欧美有码在线| 国语对白做受69|