我有多个动态生成的复选框.所以我不知道每次生成多少个复选框.我需要一些JavaScript方法来计算表单中复选框的总数.
<input type="checkBox" value="username1" name="check[0]" id="1" /><br/>
<input type="checkBox" value="userusername2" name="check[1]" id="1" /><br/>
<input type="checkBox" value="userusername3" name="check[2]" id="1" /><br/>
我无法更改复选框的名称,因为我需要将值作为数组发送到serverside PHP脚本.
解决方法:
由于所有其他答案都是基于jquery的,我将提供一个纯粹的JavaScript解决方案.假设以下形式:
<form id="myform">
<input type="checkBox" value="username1" name="check[0]" /><br/>
<input type="checkBox" value="userusername2" name="check[1]" /><br/>
<input type="checkBox" value="userusername3" name="check[2]" /><br/>
</form>
您可以使用以下逻辑计算复选框元素的数量:
<script type="text/javascript">
var myform = document.getElementById('myform');
var inputTags = myform.getElementsByTagName('input');
var checkBoxCount = 0;
for (var i=0, length = inputTags.length; i<length; i++) {
if (inputTags[i].type == 'checkBox') {
checkBoxCount++;
}
}
alert(checkBoxCount);
</script>
顺便说一句:正如其他人所说,任何HTML标记中的id属性在文档中应该是唯一的.我在上面的示例HTML中省略了你的id =“1”属性.
更新:
如果您只想计算整个页面上的所有复选框元素而不使用包含表单元素,则应该可以:
<script type="text/javascript">
var inputTags = document.getElementsByTagName('input');
var checkBoxCount = 0;
for (var i=0, length = inputTags.length; i<length; i++) {
if (inputTags[i].type == 'checkBox') {
checkBoxCount++;
}
}
alert(checkBoxCount);
</script>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。