检查所有单选按钮在本机javascript中检查

时间:2013-07-10 18:25:21

标签: javascript

我有一个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!" ;  
    }
}

1 个答案:

答案 0 :(得分:2)

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

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

然后:

if (checkRadioWrapper( r ))

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