闭包

概念

一个函数对周围状态的引用捆绑在一起,内层函数中访问到其外层函数的作用域

简单理解:闭包 = 内层函数 + 外层函数的变量,内层函数使用外层函数的变量

    function f1 () {
      const num = 1 
      function f2 () {
        console.log(num)
      }
      f2()
    }

    f1()

作用

  1. 封闭数据,提供操作,外部也可以访问函数内部的变量

        function f1 () {
          const num = 1 
          function f2 () {
            console.log(num)
          }
          return f2
        }
    
        // 实现外部访问函数内部的变量
        const re = f1()
        re()
    
  2. 实现数据的私有

    比如,我们要做个统计函数调用次数,函数调用一次,就++

    // 实现数据的私有,函数外部只能调用,不能修改
        function countFun () {
          let count = 0
    
          function fn () {
            count++
            console.log(`调用了${count}次`);
          }
          return fn
        }
    
        const re = countFun()
        re()
    

    注意:根据标记清除法可知,闭包可能引起内存泄漏

posted @ 2022-05-26 17:49  丫丫learning  阅读(26)  评论(0编辑  收藏  举报