前端設計模式之單例模式

單例模式:構造函數每次建立對象,只有一個被建立.閉包

單純寫個單例模式並不難,利用閉包,能夠私有化變量.app

 1 var single = (function(){
 2     var demo;
 3     return function(name){
 4         if(demo){
 5             return demo;
 6         }
 7         this.name = name;
 8         demo = this;
 9     }
10 })

 

 

可是想要把任何函數都變成單例模式的函數,須要利用一下工具函數:函數

function getSigleFn(fn){
    var result ;
    return function(){
        if(result){
            return result
        }
       result = fn.apply(this, arguments)//只有第一次執行;會走這裏.這個arguements是指單例之後返回的函數的參數
       return result;
    }
}

這兩個函數的寫法總結:工具

1,都是利用了閉包保存要返回的值,並判斷返回值有沒有值,有就返回,沒有就說明是第一次執行this

2,始終要弄清楚你要的結果是啥,第一個要的是事例對象,第二個要的是一個新函數.spa

相關文章
相關標籤/搜索