2

我在一个表单中输入了三个单选按钮。我希望在用户单击提交而不选择或回答所有问题时出现警报框..

这是我的表格..

<tr>
<th> Your attendance<font size="4" > </font></th>
<td>  <input type="radio" name ="v1" value = "4"    onclick="updateTotal();"/></td>
<td>  <input type="radio" name ="v1" value = "3"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v1" value = "2"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v1" value = "1"    onclick="updateTotal();" /></td>    
</tr>

<tr>
<th > Your grades  <font size="4" > </font></th>
<td>  <input type="radio" name ="v2" value = "4"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v2" value = "3"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v2" value = "2"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v2" value = "1"    onclick="updateTotal();" /></td>    
</tr>

<tr>
<th >Your self-control <font size="4" > </font></th>
<td>  <input type="radio" name ="v3" value = "4"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v3" value = "3"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v3" value = "2"    onclick="updateTotal();" /></td>
<td>  <input type="radio" name ="v3" value = "1"    onclick="updateTotal();" /></td>    
</tr> 

我试过这个javascript代码..但它不起作用没有出现警报

<script type="text/javascript">
 function validateform()
  {
    if(document.getElementsByName('v1').value="")
    {
      alert('Your grades is not selected');
    return false;
    }
  }
    </script>
4

3 回答 3

1

拿这个功能,你不能document.getElementsByName('v1').value在广播组上使用。

看看这个小提琴:http: //jsfiddle.net/JXajh/2/

function isOneChecked(name)
{
    var buttons = document.getElementsByName(name);

    for (var i = 0; i < buttons.length; i++)
    {
        if (buttons[i].checked)
        {
            return true;
        }
    }

    return false;        
}
于 2012-11-28T22:32:22.023 回答
1

那是因为getElementsByName()将返回一个 DOM 元素数组,您无法获取值或检测是否直接从该数组检查元素。您必须遍历所有元素检查是否至少检查了一个。所以是这样的:

function validateForm() {
    var radiosToValidate = ['v1', 'v2', 'v3'];
    var invalidRadios = [];
    for (i = 0; i < radiosToValidate.length; i++) {
        var currentRadioArray = documentGetElementsByName(radiosToValidate[i]);
        var currentRadioIsValid = false;
        for (j = 0; j < currentRadioArray.length; j++) {
            if (currentRadioArray[j].checked) {
                currentRadioIsValid = true;
                break;
            }
        }
        if (currentRadioIsValid === false) {
            invalidRadios[] = radiosToValidate[i];
        }
    }
    if (invalidRadios.length > 0) {
        alert('At least one radio button has not been selected');
        return false;
    }
    return true;
}
于 2012-11-28T22:36:52.083 回答
-2

你的比较有一个=,而不是一个==。您正在分配和测试"",这是虚假的,因此您的 if 语句将永远不会执行。

比较两个值的运算符是==

用这个:

if (document.getElementsByName('v1').value== "") {
  // ...
}
于 2012-11-28T22:28:59.010 回答