DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> jQuery中(function($){})(jQuery)詳解
jQuery中(function($){})(jQuery)詳解
編輯:關於JavaScript     

簡單的說

(function($){
 //code
})(jQuery)

聲明了一個匿名函數,也就是將jQuery對象作為參數傳給函數

給大家舉個例子

// 全局
var str = "全局字符串...";
(function () { // 第1層
  (function () { // 第2層
    (function () { // 第3層
      (function () { // 第4層 層數越多,訪問全局越慢
        console.time('全局');
        for (var i=0; i<1e6; i++) {
          str += Math.random().toString().substr(2, 2);
        }
        console.timeEnd('全局');
      })();
    })();
  })();
})();
 
// 局部
(function () { // 第1層
  (function () { // 第2層
    (function () { // 第3層
      (function () { // 第4層
        var str = "內部字符串...";
        var random = Math.random;
        console.time('內部');
        for (var i=0; i<1e6; i++) {
          str += random().toString().substr(2, 2);
        }
        console.timeEnd('內部');
      })();
    })()
  })();
})();

運行代碼 就可以看到效果了,比較慢,騷等片刻。
我剛剛測試發現一些內存小的電腦容易直接導致浏覽器崩潰、
chrome武裝到牙齒了,連字符串都緩存,看不出多大效果、

和速度應該沒關系,我是這麼認為的。

(function($){
// code
})(jQuery)

jQuery插件眾多,你無法確定自己使用的變量或者方法名不於其他插件重名,所以需要將所有插件代碼封裝到一個匿名函數當中;

由於插件使用了jQuery所以需要導入jQuery到匿名函數中,同時使用$變量引用(因為大家已經習慣了使用$)。當然你在全局下也可以使用$,但是無法完成第一個條件;
封裝的代碼必須執行,所以要執行匿名函數同時傳入jQuery參數。

總結

其實是為了保護$符號,不管外界是否引入了另外有干擾$的庫,都不會干擾匿名函數中$就是jQuery的事實,因為他是作為參數被傳進去的。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved