每日一题-什么是闭包?

317 阅读2分钟

闭包

阮一峰-学习闭包

「每日一题」JS 中的闭包是什么?

1.闭包是什么?

​ 闭包就是 可以读取其他函数内部变量的函数,通俗点来讲,就是在子函数作用域下可以读取父函数作用域下声明的变量,使父函数内部的变量可以在函数外面被访问。

其结构如图下:

    function f1() {

      // 注意声明变量时必须加上var关键字
      // 如果不加上var关键字声明 则声明的是一个全局变量!
      var local = '我是父函数的变量';

      // 返回 一个匿名函数 
      // ->该函数作为函数内部与函数外部的桥梁 可以访问函数内部的局部变量local
      // 形成闭包

      return function () {
        // 引用父函数的局部变量
        console.log(local);
      }
    }
    // 在函数外部调用函数f1 -> 将返回的匿名函数命名为showLocal  
    var showLocal = f1();

    // 调用showLocal函数 访问父函数的局部变量
    showLocal();//我是父函数的变量

2.闭包的作用

  • 1.闭包通常用来间接访问变量,换句话说就是隐藏变量,当你需要定义变量,并且不希望这个变量可以直接被访问到,可以通过闭包的方式进行声明,当需要改变这个变量时就调用对应的方法操作这个变量的值。

  • 2.闭包也可以用来让变量始终保持在内存中。我们通过下面代码体验

    function f1() {
          //局部变量count
          var count = 333;
    
          // 声明countHandler全局函数对count进行处理
          // 在函数外调用 -> 符合函数外部访问函数内部变量
          // 本质上 也是一个闭包
          window.countHandler = function () {
            count++;
          }
    
          return function () {
            console.log(count);
          }
        }
        // 在函数外部调用函数f1 -> 将返回的匿名函数命名为f2  
        var f2 = f1();// 333
    
        // 调用f2函数 访问函数内部变量count
        f2();
    
        // 对函数内部进行处理
        countHandler();
    
        // 再次访问函数内部的变量 观察count的变化
        f2();// 334
    

3.闭包的副作用

  • 1.由于闭包会使得函数中的变量都保存在内存中,内存的消耗很大,闭包的滥用会造成页面的性能问题。在IE中,可能会导致内存泄漏(变量无法访问到,也不能触发垃圾回收机制进行清除,造成内存的浪费)解决方法是:在退出函数之前,将不在使用的局部变量全部删除。
  • 2.闭包会在父函数外部,改变父函数内部变量的值。所以如果把父函数看做是一个对象,把闭包看作是公用方法,把内部变量看作是父函数的私有属性,那么就不能随意改变父函数内部变量的值。