JavaScript匿名函数用法分析_javascript技巧
一、定义一个函数
在JavaScript中,可以通过“函数声明”和“函数表达式”来定义一个函数,比如
1、通过“函数声明”来定义一个函数
function t1(){}
2、通过“函数表达式”来定义一个函数
t2 = function(){}
但是两种方式定义函数,效果是不同的
t1是函数声明,‘词法分析'时,AO.t1 = function(){},-------------在‘词法分析'阶段就发挥作用
t2是赋值操作,‘运行'时,AO.t2 = function(){},值是右边的表达式返回的结果,------在‘运行'阶段才发挥作用
二、匿名函数
在JavaScript中,小括号()里的语句当做表达式来执行,在上面说到,可以使用“函数表达式”来定义一个函数,那么,我们可以在()内定义一个函数,如
(function t3(){alert(' i am t3');})
如果该函数没有使用名字,修改如下
(function(){alert(' i am t3');})
包含在()内的语句既然是表达式,就有返回值,(function(){alert(' i am t3');})的返回值就是定义的函数,可以立即调用,如
(function(){alert(' i am t3');})()
因此,在小括号()内定义一个没有名字的函数,该函数称为匿名函数。这种手法,匿名函数,立即执行,不污染全局,称为 立即执行函数表达式。
三、jquery就是一个匿名函数
jquery的代码就是封装在一个匿名函数中,这是jquery最外层的代码:
(function(window,undefined){})(window);//立即调用
但是jquery为什么传window,不传undefined呢?
答:传window是为了查找速度,减少查询变量的时间。比如下面这段js代码
function(){ function(){ function(){ function(){ document.getElementById(); //这个document将会沿作用域层层上找,直到最外层window全局。 } } } }
jquery就是为了加快内部查找局部变量的速度,而直接把window以参数形式传进来, 这样window就在jquery内部AO上。
不传undefined是为了安全,因为在低版本的IE,FF中,undefined竟然可以重新赋值,如 undefined=3;
声明局部变量undefined(名字是undefined),同时,又不传参,值自然就是undefined
希望本文所述对大家的javascript程序设计有所帮助。
推荐阅读
-
JavaScript计时器用法分析【setTimeout和clearTimeout】
-
javascript中的try catch异常捕获机制用法分析
-
JavaScript事件发布/订阅模式原理与用法分析
-
JavaScript中join()、splice()、slice()和split()函数用法示例
-
JavaScript中this关键字用法实例分析
-
深入理解JavaScript 中的匿名函数((function() {})();)与变量的作用域
-
javascript自执行匿名函数
-
Javascript的匿名函数讲解
-
javascript基于原型链的继承及call和apply函数用法分析
-
JavaScript中匿名函数的递归调用