JS闭包

作者: EO_eaf6 | 来源:发表于2019-12-22 16:36 被阅读0次

    参考自:https://www.cnblogs.com/usa007lhy/p/5315670.html
    当一个函数返回它内部定义的一个函数时,就产生了一个闭包,闭包不但包括被返回的函数,还包括这个函数的定义环境。

    //闭包
    var generateClosure = function() {
      var count = 0;
      var get = function() {
        count ++;
        return count;
      };
      return get;
    };
    //普通函数
    var generateClosure_1 = function() {
      var count = 0;
      return count ++;
    };
    var counter1 = generateClosure();
    var counter2 = generateClosure();
    console.log(generateClosure_1());//执行 {var count = 0; return count ++;};
    console.log(counter);//输出返回函数 {count ++; return count;};
    console.log(generateClosure());//执行var count = 0;var get = function() {}return get;};输出返回函数 {count ++; return count;};
    console.log(counter1()); // 输出1
    console.log(counter2()); // 输出1
    console.log(counter1()); // 输出2
    console.log(counter1()); // 输出3
    console.log(counter2()); // 输出2
    

    (1)局部环境私有性:除了使用counter1,counter2,其他变量访问不到count变量,为generateClosure局部环境私有
    (2)闭包变量值“:counter1 和 counter2 分别调用了 generate-Closure() 函数,生成了两个闭包的实例,它们内部引用的 count 变量分别属于各自的运行环境。我们可以理解为,在generateClosure() 返回get 函数时,私下将 get 可能引用到的 generateClosure() 函数的内部变量(也就是 count 变量)也返回了,并在内存中生成了一个副本,之后generateClosure() 返回的函数的两个实例counter1和counter2 就是相互独立的了。

    相关文章

      网友评论

          本文标题:JS闭包

          本文链接:https://www.haomeiwen.com/subject/dzponctx.html