$(function(){})與 (function(){})() (function($){})() 的區別

1. $(function(){ }) 或 jQuery(function(){ })jquery

   此函數也能夠寫成 jQuery(function(){ }), 用於存放操做DOM對象的代碼,執行其中代碼時DOM對象已存在。不可用於存放開發插件的代碼,由於jQuery對象沒有獲得傳遞,外部經過jQuery.method也調用不了其中的方法(函數)。函數

 

2. (function(){})() 或  function(){ })(jQuery)spa

   此函數也能夠寫成   function(){ })(jQuery);其其實是執行()(para)匿名方法,只不過是傳遞了jQuery對象。用於存放開發插件的代碼,執行其中代碼時DOM不必定存在,因此若要直接自動執行DOM操做的代碼請當心使用。它至關於:插件

function wido($){} ;  wisdo(jQuery), 是初始化jquery對象的慣用方法.對象

3. (function($){...})() 或 (function($){...})(jQuery)開發

  其實是匿名函數,它等效於匿名函數 function(arg){...} ,參數爲 arg,是初始化jquery對象的慣用方法,有的時候會使頁面跳動, 在調用函數時,是在函數後面寫上括號和實參的,因爲操做符的優先級,函數自己也須要用括號,即: (function(arg){...})(param),這就至關於定義了一個參數爲arg的匿名函數,而且將param做爲參數來調用這個匿名函數,而(function($){...})(jQuery)則是同樣的,之因此只在形參使用$,是爲了避免與其餘庫衝突,因此實參用jQuery,io

例如:function

(funtion(str){alert(str)})("output"));至關於:funtion OutPutFun(str){alert(str);};OutPutFun("output");匿名函數

相關文章
相關標籤/搜索