我有一个gatherRadioBtn()函数,它在页面中发布了else else显示错误。这需要checkRadioWrapper()提示检查是否检查了所有单选按钮。
但是,true
条件未实现。我的(r[i].type == "radio") && !(r[i].checked)
表达式中是否存在错误。
将很快上传到jsfiddle
感谢。
function checkRadioWrapper()
{
for (var i=0; i < r.length; i++)
{
if ( (r[i].type == "radio") && !(r[i].checked) )
{
return false;
}
}
return true;
}
function gatherRadioBtn()
{
alert("in gather");
var r = document.getElementsByTagName("input");
var literal = [];
for (var i=0; i < r.length; i++)
{
if ( (r[i].type == "radio") && r[i].checked )
{
literal.push(r[i].name);
literal.push(r[i].value);
}
}
if (checkRadioWrapper())
{
document.getElementById("Errnodata").innerHTML = "" ;
var joinedArray = literal.join(", ");
window.opener.document.getElementById("myarray").value= joinedArray;
window.opener.getVolunteerDetails();
window.close();
}
else
{
document.getElementById("Errnodata").innerHTML = "Please select for every radio btns!" ;
}
}
答案 0 :(得分:2)
您必须将“r”作为参数传递给您的函数:
function checkRadioWrapper( r )
{
for (var i=0; i < r.length; i++)
// etc
然后:
if (checkRadioWrapper( r ))
现在,就是说,在一组共享相同名称的单选按钮中,浏览器永远不会允许同时检查所有这些按钮。因此,这真的没有多大意义。如果您的单选按钮没有与其他单选按钮共享名称,则它们应该是复选框而不是单选按钮。