我最近尝试重新使用(有效!)javascript 函数并检测到一个奇怪的行为:在 for 循环中的某个 if 语句之后,函数停止。我看不出有任何理由。
如果将实际的 if 条件更改为“1==1”,则一切正常。但是由于代码如上,我收到了第一个警报(“我们开始了”),但我从未收到过第二个警报。因此,问题无法与循环联系起来(无穷无尽或类似的东西)。但除此之外,我绝对感到困惑和无助。 (使用 Firefox 26 和 Internet Explorer 11 测试)
<!DOCTYPE html SYSTEM "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script type="text/javascript">
function my_function(number_of_divs)
{
for (var k = 0; k <= number_of_divs; k++)
{
var index = k;
if (document.getElementsByName("text_levels")[index].style.display == 'block')
{
alert('Here we go');
}
}
alert('This is never shown');
}
</script>
</head>
<body>
<a href="javascript:void" onclick="my_function(1)">Click</a>
<div name="text_levels" style="display:block">The content of a div element</div>
</body>
</html>
最佳答案
问题是您只有一个具有特定名称的元素,并且数组索引从零开始,因此您会在小于条件时停止。
for (var k = 0; k < number_of_divs; k++)
因为当它尝试使用 index=1
调用时,以下语句会抛出错误:
document.getElementsByName("text_levels")[index].style.display == 'block'
关于JavaScript 函数在某个 if 语句后停止,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21284083/