//构造函数模式相对于工厂模式来说,比较省内存。
//下面的方法是构造函数模式加上原型模式实现,构造函数模式虽说比工厂模式省内存,
//但是还是存在浪费内存的现象。
function Person(name,age,job){
this.name=name;
this.age=age;
this.job=job;
}
Person.prototype.sayName=function(){
alert(this.name);
}
Person.prototype.sayAge=function(){
alert(this.age);
}
//var person1=new Person("Nicholas",29,"software Engineer");
var person1=new Person("Tom",22,"Doctor");
var person2=new Person("Nicholas",29,"software Engineer");
person2.sayName();
person1.sayAge();
//prototype有一些验证方法:
//isPrototypeOf(),用来判断某个proptotype对象和某个实例之间的关系。
alert(Person.prototype.isPrototypeOf(person1)); //true
alert(Person.prototype.isPrototypeOf(person2)); //true
//hasOwnProperty(),用来判断某一个属性到底是本地属性,还是继承自prototype对象的属性。
alert(person1.hasOwnProperty("name"));//ture
alert(person1.hasOwnProperty("sayName"));//false
//in运算符,可以用来判断,某个实例是否含有某个属性,不管是不是本地属性
alert("name" in person1);//true
alert("sayName" in person1);//true
for(var property in person1){
alert("person1["+property+"]="+person1[property]);
}
//下面的方法是构造函数模式加上原型模式实现,构造函数模式虽说比工厂模式省内存,
//但是还是存在浪费内存的现象。
function Person(name,age,job){
this.name=name;
this.age=age;
this.job=job;
}
Person.prototype.sayName=function(){
alert(this.name);
}
Person.prototype.sayAge=function(){
alert(this.age);
}
//var person1=new Person("Nicholas",29,"software Engineer");
var person1=new Person("Tom",22,"Doctor");
var person2=new Person("Nicholas",29,"software Engineer");
person2.sayName();
person1.sayAge();
//prototype有一些验证方法:
//isPrototypeOf(),用来判断某个proptotype对象和某个实例之间的关系。
alert(Person.prototype.isPrototypeOf(person1)); //true
alert(Person.prototype.isPrototypeOf(person2)); //true
//hasOwnProperty(),用来判断某一个属性到底是本地属性,还是继承自prototype对象的属性。
alert(person1.hasOwnProperty("name"));//ture
alert(person1.hasOwnProperty("sayName"));//false
//in运算符,可以用来判断,某个实例是否含有某个属性,不管是不是本地属性
alert("name" in person1);//true
alert("sayName" in person1);//true
for(var property in person1){
alert("person1["+property+"]="+person1[property]);
}