構造器模式簡單描述(看圖): 構造器用於創建特定類型對象——準備好對象以備使用,同時接收構造器可以使用的參數,以在第一次創建對象時,設置成員屬性和方法的值 1、創建對象 新對象創建的兩種方法 <code var newObject={}; var newObject=new object();...
構造器模式簡單描述(看圖):
構造器用於創建特定類型對象——準備好對象以備使用,同時接收構造器可以使用的參數,以在第一次創建對象時,設置成員屬性和方法的值
1、創建對象
新對象創建的兩種方法
var newObject={};
var newObject=new object();//object 構造器的簡潔記法
2、基本Constructor
Javascript不支持類的情況下對象與Constructor,通過new關鍵字實例化一個對象,代碼大概是這樣的
function Car(model,year,miles){
this.model=model;
this.year=year;
this.miles=miles;
this.toString=function()
{
return this.model+"has done"+this.miles+"miles";
};
};
//用法
//可以創建car新實例
var civic=new Car("Hona Civic",2009,2000);
var mondeo=new Car("Ford Mondeo",2010,5000);
console.log(civic.toString());
console.log(mondeo.toString());
3、帶原型的Constructor
JavaScript 有prototype屬性。及調用JavaScript構造器創建一個對象後,新對象就會具有構造器原型的所有屬性。同過這種方式,可以創建多個Car對象(訪問相同的原型)
funcion() Ca(model,year,miles){
this.model=model;
this.year=year;
this.miles=miles;
//註意使用Object.prototype.newMethod 而不是Object.prototype是為了重新定義prototype對象
Car.prototype.toString=function(){
return this.model+"Has done" +this.miles+"miles";
};
};
//用法
var civic=new Car("Honda Civic",2009,20000);
var momdeo=new Car("Ford Mondeo",2010,5000);
console.log(civic.toString());
console.log(mondeo.toString());
現在toString()的單一實例就能夠在所有Car對象之間共用了