Javascript - 获取单选按钮索引号

时间:2014-02-25 15:19:36

标签: javascript arrays indexing

**我有一个带有像这样的选项数组的php页面......我需要通过javascript **获取所选选项的索引。上面我把javascript的代码不能正常工作...任何帮助将不胜感激!

 <input type="radio" name="option[1]" value="1">
<input type="radio" name="option[1]" value="2">
<input type="radio" name="option[1]" value="3">
<input type="radio" name="option[1]" value="4">

<input type="radio" name="option[2]" value="1">
<input type="radio" name="option[2]" value="2">
<input type="radio" name="option[2]" value="3">
<input type="radio" name="option[2]" value="4">

<input type="radio" name="option[3]" value="1">
<input type="radio" name="option[3]" value="2">
<input type="radio" name="option[3]" value="3">
<input type="radio" name="option[3]" value="4">
...

任何人都可以帮助我吗? 我正在尝试这样的事情,但它不起作用

   <script type="text/javascript">

    function validateForm(form) {

        for (var i = 0; i < form.elements.length; i++ ) {

            if (form.elements[i].type == 'radio') {
                if (form.elements[i].checked == true) {
                    if (form.elements[i].value  == 1 || form.elements[i].value == 6){
                        var comentario=document.getElementsByName('comentario[]'[i]);
                        var opcao = form.elements[i];
                        alert(clickedElm(opcao));
                        submitFlag = true;
                        if (comentario.value.length < 100){
                            submitFlag=false;
                            alert(i);
                        }
                        return submitFlag;
                    }

                }
            }
        }

    }
    function clickedElm(element)
    {
      var index = 0;
      for (var i = 0; document.forms[0].elements.length; i++)
      {
        if (document.forms[0].elements[i] == element)
        {
          index = i;
        }
      }
      return index;
    }
    </script>

3 个答案:

答案 0 :(得分:0)

如果我正确理解了这个问题,可以这样解决:

$(document).on('change','input[type=radio]', function(){
   alert($(this).prop('name').charAt(7));
});

这是小提琴http://jsfiddle.net/Goodluck/ynkgr/

答案 1 :(得分:0)

name属性用于对单选按钮进行分组,您必须使用id属性来访问控件,询问是否已选中。

实施例

<html>
    <head>
    </head>
    <body>
        <form id="frmTest">
            <input type="radio" name="option[1]" id="option1-item1" value="1" >
            <input type="radio" name="option[1]" id="option1-item2" value="2" >
            <input type="radio" name="option[1]" id="option1-item3" value="3" >
            <input type="radio" name="option[1]" id="option1-item4" value="4" >

            <input type="radio" name="option[2]" id="option2-item1" value="1" >
            <input type="radio" name="option[2]" id="option2-item2" value="2" >
            <input type="radio" name="option[2]" id="option2-item3" value="3" >
            <input type="radio" name="option[2]" id="option2-item4" value="4" >

            <input type="radio" name="option[3]" id="option3-item1" value="1" >
            <input type="radio" name="option[3]" id="option3-item2" value="2" >
            <input type="radio" name="option[3]" id="option3-item3" value="3" >
            <input type="radio" name="option[3]" id="option3-item4" value="4" >
        </form>

        <input type="button" onclick="validateForm(document.getElementById('frmTest'))" />

        <script type="text/javascript">

            function validateForm(form) {

                for (var i = 0; i < form.elements.length; i++ ) {

                    if (form.elements[i].type == 'radio') {
                        if (form.elements[i].checked == true) {
                            if (form.elements[i].value  == 1 || form.elements[i].value == 6){
                                var comentario=document.getElementsByName('comentario[]'[i]);
                                var opcao = form.elements[i];
                                alert(clickedElm(opcao));
                                submitFlag = true;
                                if (comentario.value.length < 100){
                                    submitFlag=false;
                                    alert(i);
                                }
                                return submitFlag;
                            }

                        }
                    }
                }

            }
            function clickedElm(element)
            {
              return element.id;
            }
        </script>
    </body>
</html>

答案 2 :(得分:0)

您忘记检查此行中的情况:
(函数中的循环clickedElm)

for (var i = 0; document.forms[0].elements.length; i++)

所以,你进入一个无限循环。

正确的一行:

for (var i = 0; i < document.forms[0].elements.length; i++)