選自《Professional Javascript For Web Developers》
其它方式:工廠方式,構造函數方式,原型方式都各有各的大缺陷,這里就不一一介紹了,想了解的可以去看一下這本著作的第3章節。
1. 混合構造函數/原型方式
優點:具有其它方式的優點而沒有其它方式的缺點
不足:封裝性欠缺
2 . 動態原型方式
function
?Car(sColor,?iDoors,?iMpg)?
{
??
this
.color?
=
?sColor;
??
this
.doors?
=
?iDoors;
??
this
.mpg?
=
?iMpg;
??
this
.drivers?
=
?
new
?Array(“Mike”,?“Sue”);


??
if
?(
typeof
?Car._initialized?
==
?“undefined”)?
{

????Car.prototype.showColor?
=
?
function
?()?
{
??????alert(
this
.color);
????}
;

????Car._initialized?
=
?
true
;
??}
}
其它方式:工廠方式,構造函數方式,原型方式都各有各的大缺陷,這里就不一一介紹了,想了解的可以去看一下這本著作的第3章節。
1. 混合構造函數/原型方式
function
?Car(sColor,?iDoors,?iMpg)?{
?? this .color? = ?sColor;
?? this .doors? = ?iDoors;
?? this .mpg? = ?iMpg;
?? this .drivers? = ? new ?Array(“Mike”,?“Sue”);
}
Car.prototype.showColor? = ? function ?()?{
??alert( this .color);
};
var ?oCar1? = ? new ?Car(“red”,? 4 ,? 23 );
var ?oCar2? = ? new ?Car(“blue”,? 3 ,? 25 );
oCar1.drivers.push(“Matt”);
alert(oCar1.drivers);? // outputs?“Mike,Sue,Matt”
alert(oCar2.drivers);? // outputs?“Mike,Sue”
?? this .color? = ?sColor;
?? this .doors? = ?iDoors;
?? this .mpg? = ?iMpg;
?? this .drivers? = ? new ?Array(“Mike”,?“Sue”);
}
Car.prototype.showColor? = ? function ?()?{
??alert( this .color);
};
var ?oCar1? = ? new ?Car(“red”,? 4 ,? 23 );
var ?oCar2? = ? new ?Car(“blue”,? 3 ,? 25 );
oCar1.drivers.push(“Matt”);
alert(oCar1.drivers);? // outputs?“Mike,Sue,Matt”
alert(oCar2.drivers);? // outputs?“Mike,Sue”
優點:具有其它方式的優點而沒有其它方式的缺點
不足:封裝性欠缺
2 . 動態原型方式




















優點:封裝性比上一個方式更好
不足:就是看上去奇怪一點,呵呵
總之,以上2種方式是目前最廣泛使用的,盡量使用它們避免不必要的問題。