闭包的特性

  • 官方解释:闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。(函数就是一个表达式)
    JavaScript中所有的function都是一个闭包。不过一般来说,嵌套的function所产生的闭包更为强大,也是大部分时候我们所谓的“闭包”。

  • 什么是闭包:闭包是指在函数外部访问函数作用域中变量(局部变量)的函数;或者说闭包就是能够读取其他函数内部变量的函数;或者说闭包是指有权访问另一个函数作用域中的变量的函数;
    由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因此可以把闭包简单理解成“定义在一个函数内部的函数”。

    通俗解释:
    闭包是指有权访问另外一个函数作用域中的变量的函数.可以理解为(能够读取其他函数内部变量的函数)

    //全局变量 全局变量降低函数的独立性

//    记数器:
     var count = 0;
     function add(){
         return count++;
     }
     console.log(add());
     console.log(add());
     console.log(add());
    //局部变量  函数执行外  局部变量销毁
     function add(){
         var count = 0;
         return count++;
     }
     console.log(add());
     console.log(add());
     console.log(add());
    //plus定义在add的内部,可以访问add局部变量count
    //f为一个全局变量,通过赋值后,成为add的返回值,也就是plus方法
    //访问到了add中的局部变量count
    //所以count虽然是局部变量,但不允许被销毁,plus就是闭包
     function add(){
         var count = 0;
         function plus(){
             return count++;
         }
         return plus;
     }
     
     var f = add();
     
     console.log(f());
     console.log(f());
     console.log(f());
    
    //变身
    function add(){
         var count = 0;
         return function(){
             return count++;
         }
     }
     
     var f = add();
         
     console.log(f());
     console.log(f());
     console.log(f());
  //继续变身
     var f = (function (){
        var count = 0;
         return function(){
             return count++;
         }
     }());
     
     console.log(f());
     console.log(f());
     console.log(f());

闭包的作用:
正常函数执行完毕后,里面声明的变量被垃圾回收处理掉,但是闭包可以让作用域里的 变量,在函数执行完之后依旧保持没有被垃圾回收处理掉

  • 可以读取函数内部的变量
  • 让这些变量的值始终保持在内存中。
  • 增加块级作用域
//java,C,C++都有块作用域,即一对花括号里定义的变量,只在该花括号里起作用。
//JS中,就算在花括号里定义的变量(会做声明的提前),属于整个函数内部
//JS中,没有块作用域,但是在闭包的写法里,可以体现出来。
function outerFunc(){
  var outVar = 10;
  var innerF = function (){
      var innerVar = 20;//该变量虽然隶属于outerFunc内部,但是它的作用域范围只在innerF对应的函数体内,属于块级作用域
  }
  alert(innerVar);
  return innerF;
}
  • 使用闭包的注意事项:
    • 由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。
    • 闭包会在父函数外部改变父函数内部变量的值。所以,如果你把父函数当作对象(object)使用,把闭包当作它的公用方法(Public Method),把内部变量当作它的私有属性(private value),这时一定要小心,不要随便改变父函数内部变量的值。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值