Javascript Class

作個記錄,javascript 如何建立類?javascript

有早期的,有原型的,有構造函數的java

// early javascript object
var o = {};
o.color = 'red';
o.showColor = function () {
    alert(this.color);
};
o.showColor();

// prototype
function Car() {}
Car.prototype.color = 'red';
Car.prototype.doors = 4;
Car.prototype.mpg = 23;
Car.prototype.drivers = new Array('Mike', 'Sue');
Car.prototype.showColor = function () {
    alert(this.color);
};
var oCar1 = new Car();
var oCar2 = new Car();
oCar1.drivers.push('Matt');
alert(oCar1.drivers); //outputs 「Mike,Sue,Matt」
alert(oCar2.drivers); //outputs 「Mike,Sue,Matt」

// prototype && constructor
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」

// Dynamic prototype method
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;
    }
}
相關文章
相關標籤/搜索