函数式编程,闭包,作用域,全局变量

 function generateClosure(){
  var count = 0;

  var get = function(){
   return ++count;
 }

  return get;
}

var counter = generateClosure();
console.log(counter()); // 1
console.log(counter()); // 2
console.log(counter()); // 3

一个函数返回它内部定义的一个函数,就产生了一个闭包,闭包不仅包括被返回的函数 ,还包括这个函数的定义环境。上面例子中,generateClosure内部的函数get被外部的变量counter引用时,counter和generateClosure的局部变量就构成了一个闭包。

 
function generateClosure(){
  var count = 0;

  var get = function(){
   return ++count;
 }

  return get;
}

var counter1 = generateClosure();
var counter2 = generateClosure();
console.log(counter1()); // 1
console.log(counter2()); // 1
console.log(counter1()); // 2
console.log(counter1()); // 3
console.log(counter2()); // 2

上面例子generateClosure调用了两次,产生了两个独立的闭包实例,二者的定义环境不一样。可以这样理解,generateClosure返回get的时候,也将get能引用到的generateClosure的局部变量也返回了,并在内存中生成了一个副本。上面的例子即使把var换成let,值类型count换成对象count{value:0}必不会影响结果。

 

转载于:https://www.cnblogs.com/dirichlet/p/7106452.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值