首页 > 其他 > 详细

组合式继承

时间:2014-12-04 13:27:07      阅读:228      评论:0      收藏:0      [点我收藏+]

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

 

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次,超类的属性既存在子类实例中,也存在子类实例的原型中。

组合式继承

原文:http://www.cnblogs.com/lcw5945/p/4142487.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!