1. 程式人生 > >Javascript 面向物件程式設計封裝問題

Javascript 面向物件程式設計封裝問題

//建構函式模式相對於工廠模式來說,比較省記憶體。
//下面的方法是建構函式模式加上原型模式實現,建構函式模式雖說比工廠模式省記憶體,
//但是還是存在浪費記憶體的現象。
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]);
}