javascript中的自執行匿名函數

格式: 
(function(){ 
          //代碼 
        })(); 

解釋:這是相當優雅的代碼(如果你首次看見可能會一頭霧水:)),包圍函數(function(){})的第一對括號向腳本返回未命名的函數,隨後一對空括號立即執行返回的未命名函數,括號內為匿名函數的參數。 
來個帶參數的例子: 
       (function(arg){ 
           alert(arg+100); 
        })(20); 
       // 這個例子返回120。 

重要用途:可以用它創建命名空間,隻要把自己所有的代碼都寫在這個特殊的函數包裝內,那麼外部就不能訪問,除非你允許 
(function(){ 
           function $(id){ 
                return document.getElementById(id); 
           } 
           function __addClass(id,className,classValue){ 
                $(id).style.className=classValue; 
           } 
           window['mySpace']={}; 
           window['mySpace']['addClass']=__addClass; 
        })(); 

     上面的例子就可以用這種偽命名空間封裝並保護自己的所有函數、對象和變量。而且,由於它們位於同一個函數中,所以可以互相引用。為瞭對受保護的代碼進行全局化,隨後的一對括號告訴瀏覽器立即執行返回的匿名函數,而且在執行期間將__addClass()賦值給瞭window的一個方法,這樣在外部隻能執行addClass而__addClass被保護起來瞭。我可以這樣調用它:mySpace.addClass('oneId','font-width','bold');

作者“disablebb”
 

發佈留言