|
1、構造函數方式
復制代碼 代碼如下:
/**
* Person類:定義一個人,有個屬性name,和一個getName方法
* @param {String} name
*/
function Person(name) {
this.name = name;
this.getName = function() {
return this.name;
}
}
這種風格讓我們這些寫過Java的有點親切在于構造一個對象需要配置一些參數,參數要賦值給類里面this。但與Java的區別是js用function來定義類,參數也無需定義類型。
類寫好了,我們造幾個對象:
復制代碼 代碼如下:
var p1 = new Person("Jack");
var p2 = new Person("Tom");
console.log(p1 instanceof Person);//true
console.log(p2 instanceof Person);//true
控制臺輸出也證明了p1,p2的確是類Person的對象實例。
這種方式的優點是:可以根據參數來構造不同的對象實例 ,缺點是構造時每個實例對象都會生成getName方法版本,造成了內存的浪費 。
當然經驗豐富的程序員用一個外部函數來代替類方法,達到了每個對象共享同一個方法。改寫后的類如下:
復制代碼 代碼如下:
//外部函數
function getName() {
return this.name;
}
function Person(name) {
this.name = name;
this.getName = getName;//注意這里
}
呵呵,有人可能覺得代碼風格有點差強人意,怎么看也沒有Java那么緊湊。但的確可以減少內存的消耗。
JavaScript技術:javascript 寫類方式之一,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。