怎样利用JavaScript中的闭包
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>
《Advanced DOM Scripting》就快交稿了!