1. 程式人生 > >獲取下拉框和單選按鈕組的值

獲取下拉框和單選按鈕組的值

一、獲取下拉列表選中項的值和文字(select)

程式碼 select.htm 示例如下:

=============================================================================

<html>

<head><title>獲取下拉列表選中項的值和文字(select)</title></head>

<body>

<script>

//獲取下拉列表選中項的文字

function getSelectedText(name){

var obj=document.getElementById(name);

for(i=0;i<obj.length;i++){

   if(obj[i].selected==true){

    return obj[i].innerText;      //關鍵是通過option物件的innerText屬性獲取到選項文字

   }

}

}

//獲取下拉列表選中項的值

function getSelectedValue(name){

var obj=document.getElementById(name);

return obj.value;      //如此簡單,直接用其物件的value屬性便可獲取到

}

</script>

<select id="myselect">

<option value="fist">1</option>

<option value="second">2</option>

<option value="third">3</option>

</select>

<input type="button"   value="所選文字"   onclick="alert(getSelectedText('myselect'));" />

<input type="button"   value="所選值" onclick="alert( getSelectedValue('myselect'));" />

</body>

</html>

=============================================================================

二、獲取單選按鈕(radio)組的值和修改選中項

看到很多帖子裡說js獲取單選按鈕(radio)組的值可以直接用document.getElementById("oper").value,雖然跟單選按鈕組一樣的下拉列表(也是列表項的陣列)也是一個數組,用這種方式可以獲到下拉列表的值,但是單選按鈕組卻獲不到所選的值。仔細研究了下,總結如下:

與下拉列表不同,單選按鈕須用this.form.oper或者document.getElementsByName('oper')方式獲取該陣列物件,document.getElementById('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){        //傳入一個物件

for(var i=0;i<oRadio.length;i++) //迴圈

{

        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.getElementById('oper')))

<input type="button" name="test2" value="按鈕2" onclick="alert('result:'+getRadio(document.getElementById('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.getElementById('slt')[2].innerText)

<input type="button" name="test6" value="按鈕6" onclick="alert(document.getElementById('slt')[2].innerText);">

</form>

</body>