其它方式:工廠方式,建構函式方式,原型方式都各有各的大缺陷,這裡就不一一介紹了,想瞭解的可以去看一下這本著作的第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”
優點:具有其它方式的優點而沒有其它方式的缺點
不足:封裝性欠缺
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 ;
}
}
優點:封裝性比上一個方式更好
不足:就是看上去奇怪一點,呵呵
總之,以上2種方式是目前最廣泛使用的,盡量使用它們避免不必要的問題。