javascript闭包的应用

在之前的日子里看了很多关于闭包的文章,不过自己没有用闭包做过什么大事,一直感觉javascript的闭包是个类似鸡肋的特性,不过通过编写一个通用js验证而引出的循环绑定事件的经历,让我完全改变了看法,感觉闭包是个十分优雅的设计,非常恰当的克服了javascript的弱点。
先来看个小例子:
 

  
  
  
  
  1. <html> 
  2. <head></head> 
  3. <body> 
  4. <ul> 
  5.     <li>1</li> 
  6.     <li>2</li> 
  7.     <li>3</li> 
  8.     <li>4</li> 
  9. </ul> 
  10. </body> 
  11. <script> 
  12. var liArr = document.getElementsByTagName("li");  
  13. var liArrliArrLength = liArr.length;  
  14. for (var i = 0; i < liArrLength; i++) {  
  15.     liArr[i].onclick = function () {  
  16.         alert(i.toString());  
  17.     }  
  18. }  
  19. </script> 
  20. </html> 

这里我为每个li绑定了onclick事件,那么事情是否如我们所愿呢?
答案是:无论你点击那个li,弹出框显示的都是4。
原因很简单,由于javascript是引用赋值,当事件绑定完成后i已经自增到4了。
那么我们如何通过闭包来解决问题呢?
 

  
  
  
  
  1. <html> 
  2. <head></head> 
  3. <body> 
  4. <ul> 
  5.     <li>1</li> 
  6.     <li>2</li> 
  7.     <li>3</li> 
  8.     <li>4</li> 
  9. </ul> 
  10. </body> 
  11. <script> 
  12. var liArr = document.getElementsByTagName("li");  
  13. var liArrliArrLength = liArr.length;  
  14. for (var i = 0; i < liArrLength; i++) {  
  15.     (function () {  
  16.         var local_i = i;  
  17.         liArr[i].onclick = function () {  
  18.             alert(local_i.toString());  
  19.         }  
  20.     })();  
  21. }  
  22. </script> 
  23. </html> 


如果曾经看过javascript闭包的同学一定会恍然大悟,您也可以观此而至。
个人认为这是闭包一个很有用的应用也是典型的案例。
说了这么多什么是闭包呢?
”官方”的解释是:所谓“闭包”,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。
这个解释很学术,不过说直白了也不是很难,就是闭包访问的外层资源不会被释放。那么什么是”变量也是该表达式的一部分“呢?
答:函数(表达式)可以访问到当时上下文环境的该变量。
只要对闭包有这个感性的认识理解上面的代码就没有任何障碍了。
首先在循环内声明了一个函数将i赋值给一个该函数变量local_i,随即又调用了这个函数。根据闭包的概念,local_i的值是当时上下文环境i的值。所以local_i不会随着i的自增而改变。

你可能感兴趣的:(JavaScript,闭包)