0

我有一个gatherRadioBtn() 函数,它发布表单否则在页面中显示错误。这从 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!" ;  
    }
}
4

1 回答 1

2

您必须将“r”作为参数传递给您的函数:

function checkRadioWrapper( r )
{
    for (var i=0; i < r.length; i++)
      // etc

接着:

if (checkRadioWrapper( r ))

现在,也就是说,在一组共享相同名称的单选按钮中,浏览器永远不会允许同时检查所有这些单选按钮。因此,这真的没有多大意义。如果您有不与其他单选按钮共享名称的单选按钮,它们应该是复选框而不是单选按钮。

于 2013-07-10T18:28:30.263 回答