首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > JavaScript >

JavaScript惯用的2种定义类的方式

2012-11-03 
JavaScript常用的2种定义类的方式1. 混合构造函数/原型方式 function Car(sColor, iDoors, iMpg) { this.c

JavaScript常用的2种定义类的方式

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种方式是目前最广泛使用的,尽量使用它们避免不必要的问题。

热点排行