一、獲取下拉列表選中項的值和文本(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="所選文本" />
<input type="button" value="所選值" />
</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" >
<br>
alert('result:'+getRadio(document.getElementById('oper')))
<input type="button" name="test2" value="按鈕2" >
<br>
alert(this.form.oper.value)
<input type="button" name="test3" value="按鈕3" >
<br>
changeRadio(this.form.oper,"上報")
<input type="button" name="test4" value="按鈕4" >
<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" >
<br>
document.getElementById('slt')[2].innerText)
<input type="button" name="test6" value="按鈕6" >
</form>
</body>
|
js怎麼取得label的值
如<label id="cvc">Label的值</label>
<script type=text/javascript>
alert(cvc.innerHTML);
</script>
js 獲取 asp.net 服務器端控件 Label 與 TextBox RadioButtonList 與 DropDownList 的值
在做 BS架構的項目時,經常遇到 需要用js 來調用 asp.net 服務器端控件的值。
大多數的 控件他的值都可以通過js調用它的 value屬性來獲得此控件的值,但是也有例外的情況。
經常用的 Label控件。他的值用js就不能通過value屬性來獲得。
Label控件 js獲取的實例, var text= document.getElementById('Label1').innerText;
假如, 這樣 var text= document.getElementById('Label1').value; 則 text 爲Undefined。
而 TextBox 的值 就可以 var text= document.getElementById('TextBox 1').value;
對於,RadioButtonList 與 DropDownList 他們的獲取方式是大不一樣的! 這主要是因爲 他們所生成的 html元素不一樣。
DropDownList 的值 獲取 比較簡單:
var ddlvalue = document.getElementById('ctl00_Contentplaceholder3_ddlFolws').value;
而 RadioButtonList 的值獲取 就比較麻煩:
var value = "";
var Result = document.getElementsByName('ctl00$Contentplaceholder3$rblResult');
for (var i = 0; i < Result.length; i++) {
if (Result.item(i).checked) {
value = Result.item(i).value;
}
}
如果 RadioButtonList 控件 沒有一個選擇的 那麼 value的值 爲空!
對於其他控件 js獲取值的方法 以後在討論。