码迷,mamicode.com
首页 > Web开发 > 详细

js循环绑定事件解决方案

时间:2015-01-19 18:45:34      阅读:187      评论:0      收藏:0      [点我收藏+]

标签:

相信大家都遇到过类似的问题,for循环绑定完事件最后执行的时候都是最后一个事件相同,比如这段代码 

<body>
<ul id="list">
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
</ul>
<script>
var list_obj = document.getElementsByTagName(‘li‘);
for (var i = 0; i <= list_obj.length; i++) {      
  list_obj[i].onclick = function() {    
    alert(i);    
  }
}
</script>
</body>

点击的时候弹出的不是0 1 2 3 4,而是5。 

解决方案也很多种,比如可以新建一个function设置一个私有方法,然后每次new一个object然后再绑定到它的方法上。 
还有就是闭包,写法相对简单: 

<body>
<ul id="list">
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
</ul>
<script>
var list_obj = document.getElementsByTagName(‘li‘);
for (var i = 0; i <= list_obj.length; i++) {    
  (function(){    
    var p = i   
    list_obj[i].onclick = function() {    
      alert(p);    
    }
  })();
}
</script>
</body>

就是每个循环加上闭包,然后设置一个临时变量,问题解决。 

js循环绑定事件解决方案

标签:

原文地址:http://www.cnblogs.com/imcty/p/4234352.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!