我有多个复选框,我想知道是否检查了其中一个。我的代码没有给我任何错误,但我没有得到我期待的结果。当我运行代码时,总是得到for循环内的第一个警报。以下是我的代码:
function validate(){
if(document.getElementById('postTW').checked || document.getElementById('postFB') ){
var checker = document.getElementsByName('twitter[]');
for (var i = 0; i < checker.length; i++) {
if(checker[i].checked){
return true;
}
else{
alert("Not enough arguments ");
return false;
}
};
}
else{
alert("Not enough arguments to submit the form");
return false;
}
}
我的表单是method = post,如下所示
<input class="twGroup" type="checkbox" name="twitter[]" value="x"/>
<input class="twGroup" type="checkbox" name="twitter[]" value="y"/>
<input class="twGroup" type="checkbox" name="twitter[]" value="z"/>
答案 0 :(得分:2)
此代码仅检查第一个复选框,因为返回:
for (var i = 0; i < checker.length; i++) {
if(checker[i].checked) {
return true;
}
else {
alert("Not enough arguments ");
return false;
}
};
试试这个:
var checked_flag = false;
for (var i = 0; i < checker.length; i++) {
if(checker[i].checked) {
checked_flag = true;
}
};
return checked_flag;
答案 1 :(得分:2)
以下代码中是否存在逻辑错误?
for (var i = 0; i < checker.length; i++) {
if(checker[i].checked){
return true;
}
else{
alert("Not enough arguments ");
return false;
}
};
我认为你想要这样的东西:
var flag=false;
for (var i = 0; i < checker.length; i++) {
if(checker[i].checked){
flag=true;
}
};
if (!flag){
alert("Not enough arguments ");
}
答案 2 :(得分:2)
如果未选中名称false
的任何复选框,请使用将返回twitter[]
的标记
function validate(){
if(document.getElementById('postTW').checked || document.getElementById('postFB').checked ){
var result = true;
var checker = document.getElementsByName('twitter[]');
for (var i = 0; i < checker.length; i++) {
if(!checker[i].checked){
alert("Not enough arguments ");
result = false;
return;
}
};
}
else{
alert("Not enough arguments to submit the form");
result = false;
}
return result
}
答案 3 :(得分:1)
您的代码中似乎有逻辑错误。如上所述,如果第一个复选框未已选中,则您将转到 else 语句并显示警告。你应该简单地删除第一个 else 语句并将第一个警报移到for循环之外:
function validate() {
if(document.getElementById('postTW').checked || document.getElementById('postFB') ) {
var checker = document.getElementsByName('twitter[]');
for (var i = 0; i < checker.length; i++) {
if(checker[i].checked){
return true;
}
};
// else fall through
alert("Not enough arguments ");
return false;
}
else {
alert("Not enough arguments to submit the form");
return false;
}
}
答案 4 :(得分:1)
围绕<form>
元素包装复选框。
显示示例:
<form name="myform">
<input type="checkbox" name="twitter[]" />
<input type="checkbox" name="twitter[]" checked="checked" />
<input type="checkbox" name="twitter[]" />
<input type="checkbox" name="twitter[]" checked="checked" />
<input type="checkbox" name="twitter[]" />
</form>
如图所示应用Javascript。
if (document.getElementById('postTW').checked || document.getElementById('postFB')) {
var myform = document.forms.myform;
var elems = myform.elements['twitter[]'];
for (var i = 0; i < elems.length; i++) {
if (elems[i].checked) {
return true;
}
}
alert("Not enough arguments to submit the form");
return false;
} else {
alert("Not enough arguments to submit the form");
return false;
}
答案 5 :(得分:0)
你认为你不应该写:
if(document.getElementById('postTW').checked || document.getElementById('postFB').checked ){
而不是:
if(document.getElementById('postTW').checked || document.getElementById('postFB') ){