3、JavaScript高级之匿名函数

来源:互联网 发布:轻薄本推荐 知乎 编辑:程序博客网 时间:2024/05/29 12:26
  • 定义一个函数

在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


0 0