js 獲取服務器控件值的代碼
2024-05-06 14:11:12
供稿:網友
一、獲取下拉列表選中項的值和文本(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;
}
//通過值修改所選中的單選按鈕