怎样利用JavaScript中的闭包
2007年12月11日 原创
JavaScript的变量作用域是通过函数来维护的。举个例子,对于函数:
function add(a,b){ return a+b; }
而言,当使用不同的参数(不带参数的函数同样如此)调用它时:
var sum1 = add(1,2);
var sum2 = add(3,4);
每次调用都会通过创建一个新的调用对象维护一个新的函数作用域,从而保证了sum1和sum2分别取得相应的 值3和7。
而闭包的原理,也是如此。下面举两个例子,一个是因为闭包导致了问题,而另一个则利用闭包巧妙地通过函数的作用域绑定参数。这两个例子相关的HTML标记片断如下:
<a href=”#” id=”closureExample”>利用闭包的例子(0.5秒后您会看到提示)</a>
<a href=”#” id=”closureExample2″>由于闭包导致问题的例子1</a>
<a href=”#” id=”closureExample3″>由于闭包导致问题的例子2</a>
<a href=”#” id=”closureExample4″>由于闭包导致问题的例子3</a>
为之漫笔(李松峰),本博客专注于Web前后端技术、移动平台开发技术、交互设计和技术翻译。声明一下,因为时常需要外出审稿,而且基本不带笔记本,所以有时可能会迟一点回复大家的留言。