`
yejian235
  • 浏览: 22793 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

JavaScript 闭包

    博客分类:
  • js
阅读更多
JavaScript很多书籍都讲的唧唧歪歪一大堆,不知道讲些什么

1、什么是闭包  
-- 函数嵌套函数  
-- 内部函数可以引用外部函数的参数和变量  
-- 参数和变量不会被垃圾回收机制回收

<script type="text/javascript">
    
     //1.1函数嵌套函数
     function Rabbit()
     {
       function shortHairGirl()
       {
         
       } 
     } 
     //1.2内部函数可以引用外部函数的参数和变量
     function Rabbit2()
     {
      var name="rabbit";//Rabbit2()执行完毕的时候,js垃圾回收器并没有对其回收
       //因为shortHairGirl()对其还有引用
      function shortHairGirl()
      {
        alert(name);
      } 
      return shortHairGirl;
     } 
     var loveShortHairGirl=Rabbit2();
     //loveShortHairGirl();
     //1.3参数和变量不会被垃圾回收机制回收 
     function GC()
     {
        var girl="我是短发美女";
     }
     GC();//当GC()执行完毕的时候,变量girl就会被js垃圾回收器,节省内存
    </script>

2、闭包的好处

       --希望一个变量长期驻扎在内存当中,避免全局变量的污染

//2.1没有使用闭包
     var girlAge=23;
     function  IncAge()
     {
       girlAge++;
       alert("短发美女的芳龄是:"+girlAge);
     }
     //IncAge();//24
     //IncAge();//25
     
      function  IncAge2()
     {
      var girlAge=22;
       girlAge++;
       alert("短发美女的芳龄是:"+girlAge);
     }
     //IncAge2();//23
     //IncAge2();//23
     
     
     function RabbitLoveGirl()
     {
         var age=22;
         return function(){
           age++;
           alert(age);
         }
     }
     var girlAge=new RabbitLoveGirl();
     //girlAge();
     //girlAge();
     
     //如果一个函数放在()中,那么就变成了函数表达式
     (
      function aaa(){
        alert(2);
      }
     )(); 
     (function(){
       alert("shit");
     })();
     
     var age=(function(){
      var a=10;
      return function(){
       a++;
       alert(a);
      }
     })();
     age();
     age();
    </script>

3、 闭包需要注意的地方【IE下可能引发内存泄露】,就不举例了。
转载自http://www.cnblogs.com/zjflove/archive/2013/05/13/3076392.html
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics