选择并向Div'添加函数;s通过For Loop
Selecting and Adding Functions to Div's via For Loop
我想快速选择div,所以我写了一个for循环,选择所有div并快速添加函数,而不是"onClick='blahblah'"方法。这是我的代码:
<!DOCTYPE html>
<html>
<head>
<title>Strategy Game Dev Test</title>
<meta charset="utf-8" />
<script type="text/javascript">
function illu_area(){
alert("test");
}
function everything(){
for(var test_id = 0; test_id < 7; test_id++){
document.getElementById("t"+test_id).addEventListener("click", illu_area());
}
}
</script>
<style type="text/css">
* { margin: 0px; padding: 0px; font-family: Tahoma}
.container_main {
margin: 10px;
width: 300px;
height: 300px;
background-color: red;
position: relative;
}
.territory_type1 {
width: 100px;
height: 100px;
position: absolute;
}
.territory_type2_horizontal {
width: 200px;
height: 100px;
position: absolute;
}
.territory_type2_vertical {
width: 100px;
height: 200px;
position: absolute;
}
#t6 {
background-color: blue;
left: 200px;
}
#t5 {
background-color: lightblue;
left: 100px;
}
#t4 {
background-color: green;
}
#t3 {
background-color: turquoise;
top: 200px;
}
#t2 {
background-color: lightgreen;
top: 200px;
left: 200px;
}
#t1 {
background-color: brown;
top: 100px;
left: 200px;
}
#t0 {
background-color: yellow;
top: 100px;
left: 100px;
}
.grid {
height: 100px;
width: 100px;
position: absolute;
top :0px;
}
#t3_g2 {
left: 100px;
}
#t4_g2 {
top: 100px;
}
</style>
</head>
<body onLoad="everything()">
<div class="container_main">
<div id="t0" class="territory_type1" data-xcoor="0" data-ycoor="0">
Origin
</div>
<div id="t1" class="territory_type1" data-xcoor="1" data-ycoor="0">
1
</div>
<div id="t2" class="territory_type1" data-xcoor="1" data-ycoor="-1">
2
</div>
<div id="t3" class="territory_type2_horizontal">
3
<div class="grid" id="t3_g1" data-xcoor="-1" data-ycoor="-1"></div>
<div class="grid" id="t3_g2" data-xcoor="0" data-ycoor="-1"></div>
</div>
<div id="t4" class="territory_type2_vertical">
4
<div class="grid" id="t4_g1" data-xcoor="-1" data-ycoor="1"></div>
<div class="grid" id="t4_g2" data-xcoor="-1" data-ycoor="0"></div>
</div>
<div id="t5" class="territory_type1" data-xcoor="0" data-ycoor="1">
5
</div>
<div id="t6" class="territory_type1" data-xcoor="1" data-ycoor="1">
6
</div>
</div>
</body>
</html>
我的问题是:当我打开这个html文件或刷新页面时,警报消息会立即出现(六次)。我希望它在我单击网格时发出警报。。。
注:
当我这样做的时候它就起作用了:
function everything(){
for(var test_id = 0; test_id < 7; test_id++){
document.getElementById("t"+test_id).addEventListener("click", function(){alert("test");});
}
}
但我认为这在未来不会有用:p
帮帮我!
您必须传递函数-省略()
.addEventListener("click", illu_area);
让()
立即执行该功能。
相关文章:
- $.mobile.changePage 之后的回调函数通过 AJAX 加载
- Javascript函数 - 通过引用复制,但这里发生了什么
- JavaScript 函数 通过调用 Element 访问此内容
- 谁能解释为什么我的日期函数通过 JS 日期对象给了我错误的转换
- 如何使用 javascript 函数通过 ID 访问 asp 控件
- JavaScript 函数通过发送下一个元素的整数来更改元素的可见性
- 角度函数通过引用传递范围变量
- javascript对象.函数通过变量调用
- javascript函数通过alert触发,但并非没有alert
- JSON构造函数通过AJAX将Javascript对象POST
- 看似正确的方式来触发Javascript函数通过链接,不工作
- 为什么返回对象的 JavaScript 函数通过引用(对其参数)来执行此操作
- 触发绑定函数;通过字符串还是调用函数
- 我正在使用jquery序列化函数通过ajax提交表单
- 如何在jquery按钮点击之前调用JS函数(通过选择器点击)
- jQuery .each()函数通过索引访问其他选择器
- JS的几个函数通过原型
- Javascript函数通过url
- 如何使用一个函数通过if/case语句调用另一个函数
- 我正在尝试创建“合并函数”.通过编写回调来工作