【发布时间】:2011-12-01 19:10:08
【问题描述】:
我想对特定功能做多个AddEventListener,但结果不是我想要的。
我总是得到名单上的最后一个孩子。
为什么?
这是代码:
第一部分:
<script>
var inside_elm= new Array();
inside_elm[1]="inside_e1";
inside_elm[2]="inside_e2";
inside_elm[3]="inside_e3";
var kk = {
showBox :function(elm){
alert(elm);
document.getElementById(elm).style.display='block';
}
}
function load() {
var e_elm= new Array();
e_elm[1]="e1";
e_elm[2]="e2";
e_elm[3]="e3";
for(var i=1;i<3;i++){
var k=e_elm[i];
alert(inside_elm[i]);
document.getElementById(e_elm[i]).addEventListener('click',function(){kk.showBox(inside_elm[i])},false);
}
}
</script>
身体:
<body onload="load();">
<div id="e1">
e1
<div id="inside_e1" style="display:none;">inside_e1</div>
</div>
<div id="e2">
e2
<div id="inside_e2" style="display:none;">inside_e2</div>
</div>
<div id="e3">
e3
<div id="inside_e3" style="display:none;">inside_e3</div>
</div>
【问题讨论】:
-
您似乎缺少
<div id="e2">的结束 div 标签。编辑:有人修复了它(也许是你),但要确保这对问题没有影响。
标签: javascript jquery events dom-events addeventlistener