jQuery中$(function(){})与(function($){})(jQuery)

一、(function($) {…})(jQuery);javascript

1)、原理:java

这其实是匿名函数,以下:闭包

function(arg){…}
这就定义了一个匿名函数,参数为arg函数

而调用函数时,是在函数后面写上括号和实参的,因为操做符的优先级,函数自己也须要用括号,即:
(function(arg){…})(param)
这就至关于定义了一个参数为arg的匿名函数,而且将param做为实参来调用这个匿名函数spa

而(function($){…})(jQuery)则是同样的,之因此只在形参使用$,是为了避免与其余库冲突,因此实参用jQuery
至关于funtion output(s){…};output(jQuery);或者var fn=function(s){…};fn(jQuery);.net

2)、做用(很是有用):blog

这种写法的最大好处是造成闭包。在(function($) {…})(jQuery)在内部定义的函数和变量只能在此范围内有效。ip

造成是否函数函数、私有变量的概念。好比:文档

[javascript] view plain copyget

  1. var i=3;  

  2. function init(){  

  3.     alert("外层init:"+i);  

  4. }  

  5. (function($) {  

  6.     var i=2;  

  7.     function init(){  

  8.         alert("内层init:"+i);  

  9.     }  

  10.   

  11.     init();  

  12. })(jQuery);  

  13. init();  


执行结果:

内层init:2

外层init:3

 

二、$(function(){…});   jQuery(function($) {…});  $(document).ready(function(){…})

这三个的做用是同样的,本人比较须要用第一种、书写简单。

文档载入完成后执行的函数。

相关文章
相关标签/搜索