單體(singleton)模式是javascript中最基本最常用的模式之一,常用來劃分命名空間、模組化代碼、減少全域變數。
下面是基本結構,沒什麼好說的。
var Singleton = {<br /> attribute1: true,<br /> attribute2: 10,<br /> method1: function() {<br /> },<br /> method2: function(arg) {<br /> }<br />};<br />Singleton.attribute1 = false;<br />var total = Singleton.attribute2 + 5;<br />var result = Singleton.method1();
擁有私人成員的單體和懶載入單體值得學習下,文法很簡單,主要是體會不同方式背後的編程思想。
以前常用底線開頭的方法表示私人,但這種方式只能作為一種規範,不能阻止別人惡意使用。藉助閉包建立私人成員是很嚴格的做法,在匿名函數中定義私人變數和方法,並返回單體對象,這樣只有單體中的方法才能夠訪問私人成員。
MyNamespace.Singleton = (function() {<br /> // Private members.<br /> var privateAttribute1 = false;<br /> var privateAttribute2 = [1, 2, 3];</p><p> function privateMethod1() {<br /> ...<br /> }<br /> function privateMethod2(args) {<br /> ...<br /> }<br /> return { // Public members.<br /> publicAttribute1: true,<br /> publicAttribute2: 10,</p><p> publicMethod1: function() {<br /> ...<br /> },<br /> publicMethod2: function(args) {<br /> ...<br /> }<br /> };<br />})();
上兩種單體都是在指令碼載入時被建立出來,對於資源密集型和配置開銷(記憶體)比較大的或者可能用不到的單體,將其執行個體化延遲到需要使用它的時候建立,這種技術被稱為懶載入或者惰性載入(lazy loading),懶載入單體稍顯複雜,但也很好理解,只有在第一次調用執行個體化一次。
MyNamespace.Singleton = (function() {</p><p> var uniqueInstance; // Private attribute that holds the single instance.</p><p> function constructor() { // 單體代碼<br /> ...<br /> }</p><p> return {<br /> getInstance: function() {<br /> if(!uniqueInstance) { // Instantiate only if the instance doesn't exist.<br /> uniqueInstance = constructor();<br /> }<br /> return uniqueInstance;<br /> }<br /> }<br />})();<br />// 調用方式<br />MyNamespace.Singleton.getInstance().publicMethod1();