
學(xué)過java,c#,vb的都知道類的概念,而類具有繼承、封裝、多態(tài)等功能。而javascript它不是面向?qū)ο笳Z言,它是解釋性語言。
但我們同樣可以使用javascript來實現(xiàn)繼承、多態(tài)。
javascript實現(xiàn)類,有多種方法。
方法一:構(gòu)造方法。
代碼
代碼如下:
function coder(){
this.name = '小王';
this.job = '程序員';
this.coding = function ()
{
alert('我正在寫代碼');
}
}
var coder=new coder();
alert(coder.name);
coder.coding();
方法二:工廠方法。
代碼
代碼如下:
function createCoderFactory(){
var obj=new Object();
obj.name = '小王';
obj.job = '程序員';
obj.coding = function (){
alert('我正在寫代碼');
};
return obj;
}
var coder = createCoderFactory();
alert(coder.name);
coder.coding();
但工廠方法和構(gòu)造方法都有著一個相同的缺點,就是每創(chuàng)建一個實例,都會實例化該類的每個函數(shù)。
方法三:原形鏈。
代碼
代碼如下:
function coder(){}
coder.prototype.name = '小王';
coder.prototype.job = '程序員';
coder.prototype.coding = function(){
alert('我正在寫代碼');
};
var coder = new coder();
alert(coder.name);
coder.coding();
注意:書上說:原型鏈有個缺點就是它所有屬性都共享,只要一個實例改變其他的都會跟著改變。 測試如下:
代碼如下:
var coder1 = new coder();
var coder2 = new coder();
alert(coder1.name); /*顯示“小王”*/
coder2.name = '老王';
alert(coder1.name); /*這個顯示“小王” 如果按書上說的應(yīng)該是顯示"老王"*/
alert(coder2.name); /*這個顯示“老王”*/
alert(coder1.name);如果按書上說的應(yīng)該是顯示"老王",但這里顯示的是“小王”,所以書上出錯了。
方法四:混合方式。
以上三種都有著各自的缺點,所以我們要加以改進(jìn)。
代碼如下:
function coder(){
this.name = '小王';
this.job = '程序員';
}
coder.prototype.coding = function(){
alert('我正在寫代碼');
};
方法五:動態(tài)原鏈。
要解決前三種的缺點,還有一種方法。
代碼
代碼如下:
function coder(){
this.name = '小王';
this.job = '程序員';
if (typeof(coder._init) == 'undefined'){
this.coding = function ()
{
alert('我正在寫代碼');
};
this._init = true;
}
}
這個方法呢,當(dāng)?shù)谝淮问褂脮r,由于_init沒初始化,就會執(zhí)行以下的代碼,實例化coding函數(shù)。以后就不會再執(zhí)行,這樣就只實例化函數(shù)一次。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com