js 用call或prototype实现类的继承

//call()
//调用一个对象的一个方法,以另一个对象替换当前对象。
//call([thisObj[,arg1[, arg2[,   [,.argN]]]]])
//参数
//thisObj 
//可选项。将被用作当前对象的对象。 
//arg1, arg2, , argN 
//可选项。将被传递方法参数序列。 
//说明
//call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。
//如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。


function Person(name){    //父类
	this.name=name;
	this.SayHello=function(){alert("Hello, I'm "+this.name);};
}
function Employee(name,salary){   //子类
	Person.call(this,name);       //将this传给父构造函数
	this.salary=salary;
	this.ShowMeTheMoney=function(){alert(this.name+" $"+this.salary);};
}

var BillGates=new Person("Bill Gates");
var SteveJobs=new Employee("Steve Jobs",1234);

BillGates.SayHello();  //显示:I'm Bill Gates
SteveJobs.SayHello();  //显示:I'm Steve Jobs
SteveJobs.ShowMeTheMoney();  //显示:Steve Jobs $1234

alert(BillGates.constructor == Person);   //true
alert(SteveJobs.constructor == Employee); //true 

直接定义prototype似乎更有extends 的意韵

function Person(name){    //父类
	this.name=name;
	this.SayHello=function(){alert("Hello, I'm "+this.name);};
}
function Employee(salary){   //子类
	this.salary=salary;
	this.ShowMeTheMoney=function(){alert(this.name+" $"+this.salary);};
}
Employee.prototype=new Person("Steve Jobs");
var SteveJobs=new Employee(1234);

SteveJobs.SayHello();  //显示:I'm Steve Jobs
SteveJobs.ShowMeTheMoney();  //显示:Steve Jobs $1234

注:这里的Person.call(this.name)就像super(this.name)一样,哥在java里都不太用,不过了解一下总是好的

posted @ 2012-04-01 09:58  xngeer  阅读(3280)  评论(0编辑  收藏  举报