看到很多帖子里说js获取单选按钮(radio)组的值可以直接用document.getElementByIdx_x("oper").value,虽然跟单选按钮组一样的下拉列表(也是列表项的数组)也是一个数组,用这种方式可以获到下拉列表的值,但是单选按钮组却获不到所选的值。仔细研究了下,总结如下:
与下拉列表不同,单选按钮须用this.form.oper或者document.getElementsByName('oper')方式获取该数组对象,document.getElementByIdx_x('oper')不能获取该数组对象(select可以)。而且要获取值须通过一循环判断获取,不能直接用.value(select可以)。而要改变单选按钮组的选中项,也须用循环判断改变各个单选按钮的value。
测试代码radio.html 如下:
=============================================================================
<html>
<head></head>
<script language="javascript">
//求单选按纽的值,适用单选项及多选项。未选返回false;有选择项,返回选项值。
function getRadio(oRadio){
var oRadioLength= oRadio.length;
var oRadioValue = false;
//alert("oRadioLength:["+oRadioLength+"]");
if (oRadioLength== undefined){
}else{
}
return oRadioValue;
}
//方法改进:
//求单选按纽的值,传radio名字作为参数。未选返回false;有选择项,返回选项值。
function getRadioValue(name){
var radioes = document.getElementsByName(name);
for(var i=0;i<radioes.length;i++)
{
}
return false;
}
//通过值修改所选中的单选按钮
function changeRadio(oRadio,oRadioValue){
for(var i=0;i<oRadio.length;i++) //循环
{
}
}
//改进:
//通过值修改所选中的单选按钮
function setRadio(name,sRadioValue){
var oRadio = document.getElementsByName(name);
for(var i=0;i<oRadio.length;i++) //循环
{
}
}
</script>
<body>
<form name="frm">
<input type="radio" name="oper" value="agree"
<input type="radio" name="oper" value="downchange" checked>下发修改</td>
<input type="radio" name="oper" value="refuse">拒保</td>
<input type="radio" name="oper" value="report" >上报 </td>
<br>
alert('result:'+getRadio(this.form.oper))
<input type="button" name="test1" value="按钮1" οnclick="alert('result:'+getRadio(this.form.oper));">
<br>
alert('result:'+getRadio(document.getElementByIdx_x('oper')))
<input type="button" name="test2" value="按钮2" οnclick="alert('result:'+getRadio(document.getElementByIdx_x('oper')));">
<br>
alert(this.form.oper.value)
<input type="button" name="test3" value="按钮3" οnclick="alert(this.form.oper.value);">
<br>
changeRadio(this.form.oper,"上报")
<input type="button" name="test4" value="按钮4" οnclick="changeRadio(this.form.oper,'report');">
<br><br><br><br>
<select id="slt">
<option value="agree" >同意</option>
<option
<option value="refuse">拒保</option>
<option
</select>
<br>
alert(this.form.slt.value)
<input type="button" name="test5" value="按钮5" οnclick="alert(this.form.slt.value);">
<br>
document.getElementByIdx_x('slt')[2].innerText)
<input type="button" name="test6" value="按钮6" οnclick="alert(document.getElementByIdx_x('slt')[2].innerText);">
</form>
</body>