组合式继承

此方式即可满足函数的复用,也可满足子类实例有各自的属性,也可传递参数。

 

function SuperType(name){

    this.name = name; //参数传递

    this.colors = [1,2]; //子类实例共有基本值

}

 

SuperType.prototype.sayName = function(){ //子类共享函数

alert(this.name);

}

 

function SubType(name,age){

SuperType.call(this,name); //继承属性

this.age = age;

}

 

//继承方法

SubType.prototype = new SuperType(); //继承原型

SubType.prototype.sayAge = function(){ //子类原型中共有方法

    alert(this.age);

}

 

var in1 = new SubType("Jack",12); //可以传递参数 

in1.colors.push(3); //访问超类的属性,而且有默认值哦

alert(in1.colors);

in1.sayName();

in1.sayAge();

 

var in2 = new SubType("Tom",30);

in2.colors.push(5); //访问超类属性,修改默认值不会影响其他的实例

alert(in2.colors);

 

此方式也有个缺点就是超类的构造函数要执行2次,超类的属性既存在子类实例中,也存在子类实例的原型中。

posted @ 2014-12-04 11:48  lcw5945  阅读(151)  评论(0编辑  收藏  举报