javascript 混合的構(gòu)造函數(shù)和原型方式,動態(tài)原型方式
更新時間:2009年12月07日 19:51:35 作者:
JS編程中最常用兩種對象類定義的方式。不管是利用下面2種方式的那一種,都可以達到相同的效果!
我們?nèi)粘S編程中最常用的方式 有下面2種:
1.混合的構(gòu)造函數(shù)和原型方式 (重點)
function car (sColor,iNumbers){ // 構(gòu)造函數(shù)只用來定義對象的所有非函數(shù)屬性,即對象的屬性
this.color = sColor;
this.numbers = iNumbers;
this.dirvers = new Array ("Jone","Leon");
}
car.prototype.showColor = function (){ // 原型方式只用來定義對象的所有函數(shù)屬性,即對象的方法
alert(this.color);
}
var car1 = new car("red");
var car2 = new car("yellow");
car1.showColor)();
car2.showColor)();
總結(jié):當你創(chuàng)建(new)一個新的對象實例car1和car2的時候,car1和car2都繼承函數(shù)對象car的所有的非函數(shù)屬性;此時在car函數(shù)外面給car函數(shù)對象的原型里面生成一個showColor方法,此時car1和car2都會引用car的原型里面的showColor方式,如果把原型方法放進car函數(shù)體里面,那么此時car1和car2不是引用的關(guān)系,而是每執(zhí)行一次函數(shù),就構(gòu)建一次showColor函數(shù),如果有100個car,那么就要重復構(gòu)造100個函數(shù)。所以要把非函數(shù)屬性和函數(shù)屬性分開來寫。
2.動態(tài)原型方式 (重點)
function car (sColor,iNumbers){ // 構(gòu)造函數(shù)只用來定義對象的所有非函數(shù)屬性,即對象的屬性
this.color = sColor;
this.numbers = iNumbers;
this.dirvers = new Array ("Jone","Leon");
if(typeof car._initialized=="undefined"){ //此時此刻,這里的car._initialized成立,繼續(xù)執(zhí)行下面的函數(shù)
car.prototype.showColor = function (){
alert(this.color);
}
}
car._initialized = true; //
執(zhí)行到這里就停止再也不在執(zhí)行第二次,因為此時此刻,car._initialized只是函數(shù)的屬性,而不是函數(shù)對象的原型屬性,如果是原型屬性的話,new一個函數(shù)對象的實例,就會改變函數(shù)里面原型對象的屬性,那么就會重復構(gòu)造showColor這個函數(shù)。正因為是這個原因,當car._initialized等于undefined的時候,執(zhí)行一次showColor,最后得到的car._initialized=true,這個時候改變的是函數(shù)的屬性,而不是函數(shù)原型的屬性,所以外部new一個對象實例根本無法改變函數(shù)的屬性,所有紅色部分的代碼就是為了做一件事情:只執(zhí)行紅色代碼之間的方法,并且每種方法只有一次,不會重復執(zhí)行!
}
var car1 = new car ("red");
var car2 = new car ("yellow");
car1.showColor();
car2.showColor();
總結(jié):不管是利用上面2種方式的那一種,都可以達到相同的效果!
方法1:混合的構(gòu)造函數(shù)和原型方式,相當于把非函數(shù)屬性和一般屬性分開來寫,這樣new 新對象的時候,不會重復構(gòu)造新函數(shù),此時引用的知識函數(shù)對象的原型方法和函數(shù)對象的屬性。但是,代碼看起來沒有封裝起來而且,不影響任何東西。
方法2:完全利用JAVA的編程代碼風格來實現(xiàn)JS的編程。這樣的好處是讓整個函數(shù)看起來像是把屬性和方法都“封裝”在一個函數(shù)體內(nèi),看起來更像一個“類”。(溫故知新:JS中其實沒有類,你要說有類,就可以把它看做一個function類),缺點是在于利用if()語句看起來不是很友好而已。
1.混合的構(gòu)造函數(shù)和原型方式 (重點)
復制代碼 代碼如下:
function car (sColor,iNumbers){ // 構(gòu)造函數(shù)只用來定義對象的所有非函數(shù)屬性,即對象的屬性
this.color = sColor;
this.numbers = iNumbers;
this.dirvers = new Array ("Jone","Leon");
}
car.prototype.showColor = function (){ // 原型方式只用來定義對象的所有函數(shù)屬性,即對象的方法
alert(this.color);
}
var car1 = new car("red");
var car2 = new car("yellow");
car1.showColor)();
car2.showColor)();
總結(jié):當你創(chuàng)建(new)一個新的對象實例car1和car2的時候,car1和car2都繼承函數(shù)對象car的所有的非函數(shù)屬性;此時在car函數(shù)外面給car函數(shù)對象的原型里面生成一個showColor方法,此時car1和car2都會引用car的原型里面的showColor方式,如果把原型方法放進car函數(shù)體里面,那么此時car1和car2不是引用的關(guān)系,而是每執(zhí)行一次函數(shù),就構(gòu)建一次showColor函數(shù),如果有100個car,那么就要重復構(gòu)造100個函數(shù)。所以要把非函數(shù)屬性和函數(shù)屬性分開來寫。
2.動態(tài)原型方式 (重點)
復制代碼 代碼如下:
function car (sColor,iNumbers){ // 構(gòu)造函數(shù)只用來定義對象的所有非函數(shù)屬性,即對象的屬性
this.color = sColor;
this.numbers = iNumbers;
this.dirvers = new Array ("Jone","Leon");
if(typeof car._initialized=="undefined"){ //此時此刻,這里的car._initialized成立,繼續(xù)執(zhí)行下面的函數(shù)
car.prototype.showColor = function (){
alert(this.color);
}
}
car._initialized = true; //
執(zhí)行到這里就停止再也不在執(zhí)行第二次,因為此時此刻,car._initialized只是函數(shù)的屬性,而不是函數(shù)對象的原型屬性,如果是原型屬性的話,new一個函數(shù)對象的實例,就會改變函數(shù)里面原型對象的屬性,那么就會重復構(gòu)造showColor這個函數(shù)。正因為是這個原因,當car._initialized等于undefined的時候,執(zhí)行一次showColor,最后得到的car._initialized=true,這個時候改變的是函數(shù)的屬性,而不是函數(shù)原型的屬性,所以外部new一個對象實例根本無法改變函數(shù)的屬性,所有紅色部分的代碼就是為了做一件事情:只執(zhí)行紅色代碼之間的方法,并且每種方法只有一次,不會重復執(zhí)行!
}
var car1 = new car ("red");
var car2 = new car ("yellow");
car1.showColor();
car2.showColor();
總結(jié):不管是利用上面2種方式的那一種,都可以達到相同的效果!
方法1:混合的構(gòu)造函數(shù)和原型方式,相當于把非函數(shù)屬性和一般屬性分開來寫,這樣new 新對象的時候,不會重復構(gòu)造新函數(shù),此時引用的知識函數(shù)對象的原型方法和函數(shù)對象的屬性。但是,代碼看起來沒有封裝起來而且,不影響任何東西。
方法2:完全利用JAVA的編程代碼風格來實現(xiàn)JS的編程。這樣的好處是讓整個函數(shù)看起來像是把屬性和方法都“封裝”在一個函數(shù)體內(nèi),看起來更像一個“類”。(溫故知新:JS中其實沒有類,你要說有類,就可以把它看做一個function類),缺點是在于利用if()語句看起來不是很友好而已。
您可能感興趣的文章:
- Javascript使用function創(chuàng)建類的兩種方法(推薦)
- Javascript 創(chuàng)建類并動態(tài)添加屬性及方法的簡單實現(xiàn)
- JS創(chuàng)建類和對象的兩種不同方式
- JavaScript中創(chuàng)建類/對象的幾種方法總結(jié)
- JavaScript創(chuàng)建類/對象的幾種方式概述及實例
- javascript最常用與實用的創(chuàng)建類的代碼
- 利用MS AJAX注冊Javascript命名空間并創(chuàng)建類
- 討論javascript(一)工廠方式 js面象對象的定義方法
- javascript工廠方式定義對象
- JavaScript中使用構(gòu)造器創(chuàng)建對象無需new的情況說明
- JavaScript設(shè)計模式之工廠模式和構(gòu)造器模式
- JS常見創(chuàng)建類的方法小結(jié)【工廠方式,構(gòu)造器方式,原型方式,聯(lián)合方式等】
相關(guān)文章
JavaScript 類的定義和引用 JavaScript高級培訓 自定義對象
在Java語言中,我們可以定義自己的類,并根據(jù)這些類創(chuàng)建對象來使用,在Javascript中,我們也可以定義自己的類,例如定義User類、Hashtable類等等。2010-04-04學習JS面向?qū)ο蟪晒?借國慶發(fā)布個最新作品與大家交流
學習JS面向?qū)ο蟪晒鑷鴳c發(fā)布個最新作品與大家交流,大家可以看下。2009-10-10

一實用的實現(xiàn)table排序的Javascript類庫
一實用的實現(xiàn)table排序的Javascript類庫...
2007-09-09