!function跟(function(){... })();函数意义相同,叫做立即运行的匿名函数(也叫立即调用函数)。
js中可以这样创建一个匿名函数:
(function(){do something...})()
//或
(function(){do something...}())
而匿名函数后面的小括号()是为了让匿名函数立即执行,其实就是一个函数调用。
这样写会报错:
function(){alert(1)}()
因为function前面没有(或者! ~之类的运算符,js解析器会试图将关键字function解析成函数声明语句,而不是函数定义表达式。
作为组运算符,小括号()会将其内部的表达式当成一个整体,然后返回结果,所以定义一个匿名函数正确的格式就是用小括号将函数体括起来。
同样的! ~ + -等运算符也有同样的效果,这是因为匿名函数也是一种值,这些运算符会将后面的函数体当成一个整体,先对匿名函数进行求值,然后在对结果进行运算。
不过这些运算符虽然能够达到让匿名函数立即执行的目的,但是要小心他们是有副作用的,比如:
!function() {return 1}()//false
~function() {return 1}()//-2
-function() {return false}()//0
-function() {return false}()//0
没错,他们会对函数的返回值进行运算,这样可能会导致最终的结果和你想要的结果不一样。当然,对于那些没有返回值的函数来说,当然是没有什么影响了。
扩展资料:
匿名函数的调用:
var abc=function(x,y){
return x+y;
}
alert(abc(2,3)); // "5"
上面的操作其实就等于换个方式去定义函数,这种用法是我们比较频繁遇到的。
例如我们在设定一个DOM元素事件处理函数的时候,我们通常都不会为他们定名字,而是赋予它的对应事件引用一个匿名函数。
使用()将匿名函数括起来,然后后面再加一对小括号(包含参数列表)。
alert((new Function("x","y","return x*y;"))(2,3));// "6"
参考资料来源:百度百科-JavaScript
( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,要理解立即执行函数,需要先理解一些函数的基本概念。
函数声明:
function fnName () {…};使用function关键字声明一个函数,再指定一个函数名,叫函数声明。
函数表达式:
var fnName = function () {…};使用function关键字声明一个函数,但未给函数命名,最后将匿名函数赋予一个变量,叫函数表达式,这是最常见的函数表达式语法形式。
匿名函数:
function () {}; 使用function关键字声明一个函数,但未给函数命名,所以叫匿名函数,匿名函数属于函数表达式,匿名函数有很多作用,赋予一个变量则创建函数,赋予一个事件则成为事件处理程序或创建闭包等等。
函数声明和函数表达式不同之处在于:
一、Javascript引擎在解析javascript代码时会‘函数声明提升'(Function declaration Hoisting)当前执行环境(作用域)上的函数声明。
而函数表达式必须等到Javascirtp引擎执行到它所在行时,才会从上而下一行一行地解析函数表达式。
二、函数表达式后面可以加括号立即调用该函数,函数声明不可以,只能以fnName()形式调用。
在function前面加!、+、 -甚至是逗号等到都可以起到函数定义后立即执行的效果,而()、!、+、-、=等运算符,都将函数声明转换成函数表达式。
消除了javascript引擎识别函数表达式和函数声明的歧义,告诉javascript引擎这是一个函数表达式,不是函数声明,可以在后面加括号,并立即执行函数的代码。
扩展资料
作用:
javascript中没用私有作用域的概念,如果在多人开发的项目上,你在全局或局部作用域中声明了一些变量,可能会被其他人不小心用同名的变量给覆盖掉。
根据javascript函数作用域链的特性,可以使用这种技术可以模仿一个私有作用域,用匿名函数作为一个“容器”。
“容器”内部可以访问外部的变量,而外部环境不能访问“容器”内部的变量,所以( function(){…} )()内部定义的变量不会和外部的变量发生冲突,俗称“匿名包裹器”或“命名空间”。
JQuery使用的就是这种方法,将JQuery代码包裹在( function (window,undefined){…jquery代码…} (window)中,在全局作用域中调用JQuery代码时,可以达到保护JQuery内部变量的作用。
( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,要理解立即执行函数,需要先理解一些函数的基本概念。
函数声明:
function fnName () {…};使用function关键字声明一个函数,再指定一个函数名,叫函数声明。
函数表达式:
var fnName = function () {…};使用function关键字声明一个函数,但未给函数命名,最后将匿名函数赋予一个变量,叫函数表达式,这是最常见的函数表达式语法形式。
匿名函数:
function () {}; 使用function关键字声明一个函数,但未给函数命名,所以叫匿名函数,匿名函数属于函数表达式,匿名函数有很多作用,赋予一个变量则创建函数,赋予一个事件则成为事件处理程序或创建闭包等等。
函数声明和函数表达式不同之处在于:
一、Javascript引擎在解析javascript代码时会‘函数声明提升'(Function declaration Hoisting)当前执行环境(作用域)上的函数声明。
而函数表达式必须等到Javascirtp引擎执行到它所在行时,才会从上而下一行一行地解析函数表达式。
二、函数表达式后面可以加括号立即调用该函数,函数声明不可以,只能以fnName()形式调用。
在function前面加!、+、 -甚至是逗号等到都可以起到函数定义后立即执行的效果,而()、!、+、-、=等运算符,都将函数声明转换成函数表达式。
消除了javascript引擎识别函数表达式和函数声明的歧义,告诉javascript引擎这是一个函数表达式,不是函数声明,可以在后面加括号,并立即执行函数的代码。
扩展资料
作用:
javascript中没用私有作用域的概念,如果在多人开发的项目上,你在全局或局部作用域中声明了一些变量,可能会被其他人不小心用同名的变量给覆盖掉。
根据javascript函数作用域链的特性,可以使用这种技术可以模仿一个私有作用域,用匿名函数作为一个“容器”。
“容器”内部可以访问外部的变量,而外部环境不能访问“容器”内部的变量,所以( function(){…} )()内部定义的变量不会和外部的变量发生冲突,俗称“匿名包裹器”或“命名空间”。
JQuery使用的就是这种方法,将JQuery代码包裹在( function (window,undefined){…jquery代码…} (window)中,在全局作用域中调用JQuery代码时,可以达到保护JQuery内部变量的作用。
一个function,你就把他看成是一个代码片段,function是不是嵌套function其实是没有什么意义的,你把里面的那个function拿到外面就是全局的,把function写在里面就是局部的,就和我们声明一个var i=0;一样,你放在的部位不同,调用时的约束就不同(也就是一个是全局、一个不是全局的问题)。
首先来拆分下 !function(e){}() js 这句代码。
“!”+"function(e){}" +"()",function(e){}当然是一个方法,后面跟上括号,就相当于执行了这个方法。最后使用“!”对返回的结果进行取反。所以执行的结果会返回 true。
用括号括起来代表马上执行。
我们平常的调用一个函数是这样:
function myFunction(){
//function content
}
myFunction();//这里调用
这个其实就你上面的代码一样的,只不过你上面的代码使用的是匿名函数,定义完马上就被调用了。
在JavaScript中函数就是一个对象,你可以这样理解。其实这:function(window,undefined){}就是一个对象,我给的例子myFunciotn()也是作为
/*下面这个函数其实就是Function的对象,它跟:
var myFunction = new Function(); 是等价的,它又将作为window的属性存在着
*/
function myFunction(){
//function content
}
它的一个对象存在着(你知道,JavaScript中对象也可以有自己的对象属性)。这样看他们都是一样-是一个对象。
为什么很多地方都使用你说的那种形式来写JavaScript的代码呢?
因为在JavaScript中代码的效率非常重要,一个函数对象在被执行完了之后,系统就会将它销毁,但是如果是一个全局属性的话,只有等到整个窗口被销毁的时候这些属性才会被销毁。像我上面那样的写法,myFucntion()函数在被执行完之后会被系统立马销毁掉,但是函数
function myFunction(){
//function content
}
还会作为一个全局的属性(前提是我们将它定义成全局)直到窗口销毁它才会被销毁,但是我们后面不会再调用它了。这样,如果有很有这样的属性或者是函数的话,会白白的浪费很多的系统资源。(function(window,undefined){})(window);这种写法就很合理了,这个函数执行完之后立马就被销毁掉,节省了系统的开销。
扩展
看了你的回答有种恍然大悟的感觉,说的很好,再深入一点,那三个参数是什么意思,有什么作用
function是函数的意思吧!就是标记这是一个函数的意思!具体的资料我没有,可以上网去查,不过声明函数都要用到function!
function()是JS函数,类似于java中的方法,C中的函数
按钮
以上的含义就是在点击这个按钮的时候,执行formSubmit()这个函数,完成一个窗口的弹出,内容是你好
这样的语句一般伴随着变量赋值同时出现才更有意义。
具体是怎么一回事,请看我以往给网友解答的提问,这里给这种语法结构做了细致的分析。
相信你看过之后,就对其作用清晰明了了:
【JavaScript新手问题】http://zhidao.baidu.com/question/558917999?&oldq=1
这是jquery的函数写法、
扩展
关键我想知道的是这个$所表示的意义,是不是在IE或是所有的浏览器中都有这种类似的方法,我想这应该是一个驱动事件,只是不知道是什么驱动事件