首頁 > web前端 > js教程 > JavaScript物件導向(極簡主義法minimalist approach)_js物件導向

JavaScript物件導向(極簡主義法minimalist approach)_js物件導向

WBOY
發布: 2016-05-16 17:51:43
原創
1269 人瀏覽過
極簡主義法
  荷蘭程式設計師Gabor de Mooij 提出了一種比Object.create ()更好的新方法,他稱這種方法為"極簡主義法"(minimalist approach) 。這也是我推薦的方法。
  3. 1 封裝
  這種方法不使用 this 和 prototype,程式碼部署起來非常簡單,這大概也是它被叫做"極簡主義法"的原因。
  首先,它也是用一個物件模擬"類"。在這個類別裡面,定義一個建構子 createNew (),用來產生實例。
複製程式碼 程式碼如下:

var Cat = { // some code here
}
};

  然後,在createNew ()裡面,定義一個實例對象,把這個實例物件當作傳回值。

複製程式碼 程式碼如下:
var Cat = { var cat = {};
cat.name = "大毛";
cat.makeSound = function (){ alert ("喵喵喵"); };
return cat;
}
};


  使用的時候,呼叫createNew ()方法,就可以得到實例物件。


複製程式碼 程式碼如下:
var cat1 = Catcreate (New); cat1.makeSound (); // 喵喵喵


  這種方法的好處是,容易理解,結構清晰優雅,符合傳統的"物件導向程式設計"的構造,因此可以方便地部署下面的特性。
  3. 2 繼承

  讓一個類別繼承另一個類,實作起來很方便。只要在前者的 createNew ()方法中,呼叫後者的 createNew ()方法即可。   先定義一個 Animal 類別。


複製程式碼 程式碼如下: var Animal = { create) {
var animal = {};
animal.sleep = function (){ alert ("睡懶覺"); };
return animal;
}
};


  然後,在Cat 的createNew ()方法中,呼叫Animal 的createNew ()方法。



複製程式碼
程式碼如下: var Cat = { var cat = Animal.createNew ();
cat.name = "大毛";
cat.makeSound = function (){ alert ("喵喵喵"); };
return cat;
}
};


  這樣得到的Cat 實例,就會同時繼承Cat 類別和Animal 類別。



複製程式碼
  
3. 3 私有屬性與私有方法

  在createNew ()方法中,只要不是定義在cat 物件上的方法和屬性,都是私有的。


複製程式碼

程式碼如下: var Cat = { var cat = {}; var sound = "喵喵喵"; cat.makeSound = function (){ alert (sound); };
return cat;
}
};


  上例的內部變數sound,外部無法讀取,只有透過cat 的公有方法makeSound ()來讀取。




複製程式碼


程式碼如下:
  有時候,我們需要所有實例物件,能夠讀寫同一項內部資料。這時候,只要把這個內部數據,封裝在類別物件的內部、createNew ()方法的外面即可。



複製程式碼
程式碼如下:

var Cat = {
sound : "喵喵喵",
createNew: function (){
var cat = {};
cat.makeSound = function (){ alert (Cat.sound); };
cat.changeSound = function (x){ Cat.sound = x; };
return cat;
}
};

  然後,產生兩個實例物件:
複製程式碼 程式碼如下:


程式碼如下:


程式碼cat1 = Cat.createNew ();
var cat2 = Cat.createNew ();
複製程式碼


程式碼如下:
cat2.changeSound ("啦啦啦"); 🎜>cat1.makeSound (); // 啦啦啦
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板