日期:2014-05-16  浏览次数:20427 次

js获取下拉列表选中项的值和文本(select)以及获取单

一、获取下拉列表选中项的值和文本(select)

代码 select.htm 示例如下:

=============================================================================
<html>
<head><title>获取下拉列表选中项的值和文本(select)</title></head>
<body>
<script>

//获取下拉列表选中项的文本
function getSelectedText(name){
var obj=document.getElementByIdx_x(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.getElementByIdx_x(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.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){???????