在Javascript中闭包(Closure)

Javascript中闭包(Closure)
什么是闭包
“官方”的解释是:所谓“闭包”,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(一般是一个函数),于是这些变量也是该表达式的一部分。
相信不多有人能直接看懂这句话,由于他描述的太学术。我想用如何在Javascript中建立一个闭包来告诉你什么是闭包,由于跳过闭包的建立过程直接理解闭包的定义是很是困难的。看下面这段

代码

1
2
3
4
5
6
7
8
9
function  a(){
var  i=0;
function  b(){
alert(++i);
}
return  b;
}
var  c=a();
c();

特色

这段代码有两个特色:
一、函数b嵌套在函数a内部;
二、函数a返回函数b。
这样在执行完var c=a( )后,变量c其实是指向了函数b,再执行c( )后就会弹出一个窗口显示i的值(第一次为1)。这段代码其实就建立了一个闭包,为何?由于函数a外的变量c引用了函数a内的函数b,就是说:
当函数a的内部函数b被函数a外的一个变量引用的时候,就建立了一个闭包。

做用

简而言之,闭包的做用就是在a执行完并返回后,闭包使得Javascript的垃圾回收机制不会收回a所占用的资源,由于a的内部函数b的执行须要依赖a中的变量。这是对闭包做用的很是直白的描述,不专业也不严谨,但大概意思就是这样,理解闭包须要按部就班的过程。
在上面的例子中,因为闭包的存在使得函数a返回后,a中的i始终存在,这样每次执行c(),i都是自加1后alert出i的值。
那 么咱们来想象另外一种状况,若是a返回的不是函数b,状况就彻底不一样了。由于a执行完后,b没有被返回给a的外界,只是被a所引用,而此时a也只会被b引 用,所以函数a和b互相引用但又不被外界打扰(被外界引用),函数a和b就会被回收。(关于Javascript的垃圾回收机制将在后面详细介绍)

另外一个例子

模拟私有变量
function Counter(start){
var count = start;
  return{
  increment:function(){
  count++;
  },
  get:function(){
  return count;
  }
  }
  }
  var foo =Counter(4);
  foo.increment();
  foo.get();// 5

结果

这里,Counter 函数返回两个闭包,函数 increment 和函数 get。 这两个函数都维持着 对外部做用域 Counter 的引用,所以总能够访问此做用域内定义的变量 count.
相关文章
相关标签/搜索