一、(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
var i=3;
function init(){
alert("外层init:"+i);
}
(function($) {
var i=2;
function init(){
alert("内层init:"+i);
}
init();
})(jQuery);
init();
执行结果:
内层init:2
外层init:3
二、$(function(){…}); jQuery(function($) {…}); $(document).ready(function(){…})
这三个的做用是同样的,本人比较须要用第一种、书写简单。
文档载入完成后执行的函数。