作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想将“y”变量传递给 okayid,但循环似乎有问题。循环在 okay.item(y) 上第一次调用“y”时工作正常,但它没有循环遍历 okayid.item(y)。在我看来,这是一个范围问题,但我不确定。
var okay = document.getElementsByClassName("Okay");
var okayid = document.getElementsByClassName("OkayID");
var numberOkays = okay.length;
for(y = 0; y <= numberOkays; y++){
okay.item(y).onclick = function(){
xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function(){
if(xmlhttp.readyState == 4 && xmlhttp.status == 200){
alert('vote Sent to picture with id = ' + okayid.item(y).innerHTML);
}
};
xmlhttp.open("GET", "ajax/vote.php", true);
xmlhttp.send();
};
}
这是 html ...
<a class="Link1A Okay" href="#"><span class="OkayID">[id]</span><div class="Vote1A">Okay</div></a>
最佳答案
你有很多问题。
y
与 var
这可能会导致问题,就像现在一样y
是全局范围的一部分。y <= numberOkays
这将导致在末尾检索到一个空元素,因为 numberOkays 是数组长度的结果。所以你会没事的[y] 最后是未定义的。y
将在最后一个索引处,因此当点击事件被触发时,当您引用 Okay[y]
时,您总是会得到最后一个元素。 (或者在你的情况下,你会因为问题 2 而变得不确定)。使用它会引用点击的元素,这实际上是您对 Okay[y]
的预期。 .这是您的代码的更新版本,下面有一个指向可用 jsFiddle 的链接:
var okay = document.getElementsByClassName("Okay");
for(var y = 0; y < okay.length; y++){
okay[y].onclick = function(){
idElem = this.getElementsByClassName("OkayID")[0];
xmlhttp = new XMLHttpRequest();
xmlhttp.onreadystatechange = function(){
if(xmlhttp.readyState == 4 && xmlhttp.status == 200){
alert('vote Sent to picture with id = ' + idElem.innerHTML);
}
};
xmlhttp.open("GET", "ajax/vote.php", true);
xmlhttp.send();
};
}
关于javascript - 如何使用 for 循环遍历函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27669001/
我是一名优秀的程序员,十分优秀!