javascript实现继承的多种方式

 

对象冒充

function ClassA(sColor){

this.color=sColor;

this.sayColor=function(){

window.alert(this.color);

};

}

 

function ClassB(sColor,sName){

this.newMethod=ClassA;

this.newMethod(sColor);

delete this.newMethod;

this.name=sName;

this.sayName=function(){

window.alert(this.name);

};

}

 

var objA=new ClassA("red");

var objB=new ClassB("blue","Nicholas");

objA.sayColor();

objB.sayColor();

objB.sayName();

 

 

 

call方法

function ClassA(sColor){

this.color=sColor;

this.sayColor=function(){

window.alert(this.color);

};

}

 

function ClassB(sColor,sName){

ClassA.call(this,sColor);

this.name=sName;

this.sayName=function(){

window.alert(this.name);

};

}

 

var objA=new ClassA("red");

var objB=new ClassB("blue","Nicholas");

objA.sayColor();

objB.sayColor();

objB.sayName();

 

 

 

apply方法

function ClassA(sColor){

this.color=sColor;

this.sayColor=function(){

window.alert(this.color);

};

}

 

function ClassB(sColor,sName){

//ClassA.apply(this,new Array(sColor));

ClassA.apply(this,arguments);

this.name=sName;

this.sayName=function(){

window.alert(this.name);

};

}

 

var objA=new ClassA("red");

var objB=new ClassB("blue","Nicholas");

objA.sayColor();

objB.sayColor();

objB.sayName();

 

 

 

 

混合模式

function ClassA(sColor){

this.color=sColor;

}

 

ClassA.prototype.sayColor=function(){

window.alert(this.color);

};

 

function ClassB(sColor,sName){

ClassA.call(this,sColor);

this.name=sName;

}

 

ClassB.prototype=new ClassA();

 

ClassB.prototype.sayName=function(){

window.alert(this.name);

};

 

var objA=new ClassA("red");

var objB=new ClassB("blue","Nicholas");

objA.sayColor();

objB.sayColor();

objB.sayName();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值