JS利用prototype給類添加方法操作詳解
本文實(shí)例講述了JS利用prototype給類添加方法操作。分享給大家供大家參考,具體如下:
1.如何定義一個(gè)簡(jiǎn)單的類?
以下是一個(gè)沒(méi)有任何屬性和方法的類的定義:
function MyClass(){};
你可能會(huì)想,這不就是個(gè)簡(jiǎn)單的函數(shù)聲明?沒(méi)錯(cuò),這個(gè)函數(shù)就是一個(gè)類的定義的實(shí)現(xiàn)。如何使用這個(gè)類呢?看下面的代碼:
var cls1 = new MyClass();
這樣,利用new就可以生成MyClass的一個(gè)實(shí)例了。所以在js中可以說(shuō)函數(shù)就是類,類就是函數(shù)。
2.給類增加屬性和方法
function MyClass(name,age){
this.name = name;
this.age = age;
}
var cls1 = new MyClass("lily",18);
alert(cls1.name);
從上面的代碼可以看出,在函數(shù)內(nèi)使用this就能給函數(shù)本身增加屬性值。而在上面的代碼中就給myClass函數(shù)增加了name和age屬性。
同樣,還可以利用this給這個(gè)類增加一個(gè) 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();
我們已經(jīng)成功的給MyClass增加了toString方法。另外也可以用以下代碼來(lái)添加方法:
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(); //報(bào)錯(cuò)
雖然這樣也能給這個(gè)類添加一個(gè)方法,但這種方式只是給cls1這個(gè)實(shí)例增加了方法,并未給MyClass本身增加方法。
cls2并不存在toString方法。
3.引出prototype
從上面我們已經(jīng)知道要給MyClss類的本身增加方法,需要講方法定義在MyClass這個(gè)函數(shù)內(nèi)部,這樣的話,每聲明一個(gè)新的實(shí)例,就會(huì)將MyClass本身復(fù)制一遍,這顯然不是最優(yōu)的做法。
既然不能將一個(gè)類(函數(shù))所包含的方法都定義在函數(shù)的內(nèi)部,那么,如何來(lái)給一個(gè)類添加方法呢?這就需要用到函數(shù)的prototype屬性了。
每一個(gè)函數(shù)都會(huì)包含一個(gè)prototype屬性,這個(gè)屬性指向了一個(gè)prototype對(duì)象,我們可以指定函數(shù)對(duì)應(yīng)的prototype對(duì)象。如果不指定,則函數(shù)的prototype屬性將指向一個(gè)默認(rèn)的prototype對(duì)象,并且次默認(rèn)的prototype對(duì)象的constructor屬性又會(huì)指向該函數(shù)。
當(dāng)用構(gòu)造函數(shù)創(chuàng)建一個(gè)新的對(duì)象時(shí),新的對(duì)象會(huì)獲取構(gòu)造函數(shù)的prototype屬性所指向的prototype對(duì)象的所有屬性和方法,這樣一來(lái),構(gòu)造函數(shù)對(duì)應(yīng)的prototype對(duì)象所做的任何操作都會(huì)反映到它所生成的對(duì)象上,所有的這些對(duì)象將共享與構(gòu)造函數(shù)對(duì)應(yīng)的prototype對(duì)象的屬性和方法。
雖然新創(chuàng)建的對(duì)象可以使用它的構(gòu)造函數(shù)所指向的prototype對(duì)象的屬性和方法,但不能像構(gòu)造函數(shù)那樣直接調(diào)用prototype對(duì)象(對(duì)象沒(méi)有prototype屬性)。
簡(jiǎn)而言之,就是如果我們使用函數(shù)的prototype對(duì)象來(lái)給函數(shù)添加方法,那么在創(chuàng)建一個(gè)新的對(duì)象的時(shí)候,并不會(huì)復(fù)制這個(gè)函數(shù)的所有方法,而是指向了這函數(shù)的所有方法。
具體看下面的代碼:
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();
如果要加入多個(gè)方法,也可以使用下面的方式:
function MyClass(name,age){
this.name = name;
this.age = age;
}
MyClass.prototype = {
toString:function(){
//
},
sayHellow:function(){
//
}
};
這就是js中給類添加方法的實(shí)現(xiàn),它是利用prototype來(lái)實(shí)現(xiàn)封裝的。
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
相關(guān)文章
利用JavaScript實(shí)現(xiàn)仿京東放大鏡效果
這篇文章主要為大家詳細(xì)介紹了如何利用JavaScript實(shí)現(xiàn)仿京東放大鏡特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
JavaScript撤銷恢復(fù)操作的實(shí)現(xiàn)方法詳解
這篇文章主要介紹了JavaScript撤銷恢復(fù)操作的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-02-02
JSON格式的時(shí)間/Date(2367828670431)/格式轉(zhuǎn)為正常的年-月-日 格式的代碼
這篇文章主要介紹了JSON格式的時(shí)間/Date(2367828670431)/格式轉(zhuǎn)為正常的年-月-日 格式的代碼的相關(guān)資料,需要的朋友可以參考下2016-07-07
淺談JavaScript暫時(shí)性死區(qū)與垃圾回收機(jī)制
本文主要介紹了淺談JavaScript暫時(shí)性死區(qū)與垃圾回收機(jī)制,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05
擴(kuò)展bootstrap的modal模態(tài)框-動(dòng)態(tài)添加modal框-彈出多個(gè)modal框
這篇文章主要介紹了擴(kuò)展bootstrap的modal模態(tài)框-動(dòng)態(tài)添加modal框-彈出多個(gè)modal框,需要的朋友可以參考下2017-02-02
JavaScript解析任意形式的json樹型結(jié)構(gòu)展示
這篇文章主要介紹了JavaScript解析任意形式的json樹型結(jié)構(gòu)展示的相關(guān)資料,需要的朋友可以參考下2017-07-07
MUI頂部選項(xiàng)卡的用法(tab-top-webview-main)詳解
最近用MUI做手機(jī)app應(yīng)用的時(shí)候,遇到的小bug,這里小編給大家分享MUI頂部選項(xiàng)卡的用法(tab-top-webview-main)詳解,感興趣的朋友一起看看吧2017-10-10
深入淺出理解JavaScript高級(jí)定時(shí)器原理與用法
這篇文章主要介紹了JavaScript高級(jí)定時(shí)器原理與用法,結(jié)合實(shí)例形式分析了javascript重復(fù)定時(shí)器相關(guān)問(wèn)題與解決方法,并描述了函數(shù)節(jié)流的原理與相關(guān)操作方法,需要的朋友可以參考下2018-08-08

