JS闭包

2019-12-22  本文已影响0人  EO_eaf6

参考自: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 就是相互独立的了。

上一篇下一篇

猜你喜欢

热点阅读