js獲取單選按鈕(radio)組的值和修改選中項
看到很多帖子裡說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){
if (oRadio.checked){
oRadioValue = oRadio.value;
}
}else{
for (i=0;i<oRadioLength;i++){
//alert("oRadio["+i+"]:"+oRadio[i].checked+"/"+oRadio[i].value);
if (oRadio[i].checked){
oRadioValue = oRadio[i].value;
break;
}
}
}
return oRadioValue;
}
//方法改進:
//求單選按紐的值,傳radio名字作為引數。未選返回false;有選擇項,返回選項值。
function getRadioValue(name){
var radioes = document.getElementsByName(name);
for(var i=0;i<radioes.length;i++)
{
if(radioes[i].checked){
return radioes[i].value;
}
}
return false;
}
//通過值修改所選中的單選按鈕
function changeRadio(oRadio,oRadioValue){ //傳入一個物件
{
if(oRadio[i].value==oRadioValue) //比較值
{
oRadio[i].checked=true; //修改選中狀態
break; //停止迴圈
}
}
}
//改進:
//通過值修改所選中的單選按鈕
function setRadio(name,sRadioValue){ //傳入radio的name和選中項的值
var oRadio = document.getElementsByName(name);
for(var i=0;i<oRadio.length;i++) //迴圈
{
if(oRadio[i].value==sRadioValue) //比較值
{
oRadio[i].checked=true; //修改選中狀態
break; //停止迴圈
}
}
}
</script>
<body>
<form name="frm">
<input type="radio" name="oper" value="agree" >同意</td>
<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" onclick="alert('result:'+getRadio(this.form.oper));">
<br>
alert('result:'+getRadio(document.getElementByIdx_x('oper')))
<input type="button" name="test2" value="按鈕2" onclick="alert('result:'+getRadio(document.getElementByIdx_x('oper')));">
<br>
alert(this.form.oper.value)
<input type="button" name="test3" value="按鈕3" onclick="alert(this.form.oper.value);">
<br>
changeRadio(this.form.oper,"上報")
<input type="button" name="test4" value="按鈕4" onclick="changeRadio(this.form.oper,'report');">
<br><br><br><br>
<select id="slt">
<option value="agree" >同意</option>
<option value="downchange" selected>下發修改</option>
<option value="refuse">拒保</option>
<option value="report">上報</option>
</select>
<br>
alert(this.form.slt.value)
<input type="button" name="test5" value="按鈕5" onclick="alert(this.form.slt.value);">
<br>
document.getElementByIdx_x('slt')[2].innerText)
<input type="button" name="test6" value="按鈕6" onclick="alert(document.getElementByIdx_x('slt')[2].innerText);">
</form>
</body>