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惰性载入函数实例分析
-
JavaScript的级联函数用法简单示例【链式调用】
-
JavaScript内置对象math,global功能与用法实例分析
-
javascript回调函数的概念理解与用法分析
-
javascript函数定义以及常见用法
-
JavaScript寄生组合式继承原理与用法分析
-
JavaScript函数式编程(Functional Programming)声明式与命令式实例分析
-
JavaScript函数式编程(Functional Programming)高阶函数(Higher order functions)用法分析
-
JavaScript函数式编程(Functional Programming)箭头函数(Arrow functions)用法分析
-
JavaScript函数式编程(Functional Programming)组合函数(Composition)用法分析