zl程序教程

您现在的位置是:首页 >  后端

当前栏目

js获取服务器控件值的代码

JS服务器代码 获取 控件
2023-06-13 09:14:16 时间
一、获取下拉列表选中项的值和文本(select)
代码select.htm示例如下:
复制代码代码如下:

<html>
<head><title>获取下拉列表选中项的值和文本(select)</title></head>
<body>
<script>
//获取下拉列表选中项的文本
functiongetSelectedText(name){
varobj=document.getElementById(name);
for(i=0;i<obj.length;i++){
if(obj[i].selected==true){
returnobj[i].innerText;//关键是通过option对象的innerText属性获取到选项文本
}
}
}
//获取下拉列表选中项的值
functiongetSelectedValue(name){
varobj=document.getElementById(name);
returnobj.value;//如此简单,直接用其对象的value属性便可获取到
}
</script>
<selectid="myselect">
<optionvalue="fist">1</option>
<optionvalue="second">2</option>
<optionvalue="third">3</option>
</select>
<inputtype="button"value="所选文本"/>
<inputtype="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>
<scriptlanguage="javascript">
//求单选按纽的值,适用单选项及多选项。未选返回false;有选择项,返回选项值。
functiongetRadio(oRadio){
varoRadioLength=oRadio.length;
varoRadioValue=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;
}
}
}
returnoRadioValue;
}
//方法改进:
//求单选按纽的值,传radio名字作为参数。未选返回false;有选择项,返回选项值。
functiongetRadioValue(name){
varradioes=document.getElementsByName(name);
for(vari=0;i<radioes.length;i++)
{
if(radioes[i].checked){
returnradioes[i].value;
}
}
returnfalse;
}
//通过值修改所选中的单选按钮
functionchangeRadio(oRadio,oRadioValue){//传入一个对象
for(vari=0;i<oRadio.length;i++)//循环
{
if(oRadio[i].value==oRadioValue)//比较值
{
oRadio[i].checked=true;//修改选中状态
break;//停止循环
}
}
}
//改进:
//通过值修改所选中的单选按钮
functionsetRadio(name,sRadioValue){//传入radio的name和选中项的值
varoRadio=document.getElementsByName(name);
for(vari=0;i<oRadio.length;i++)//循环
{
if(oRadio[i].value==sRadioValue)//比较值
{
oRadio[i].checked=true;//修改选中状态
break;//停止循环
}
}
}
</script>
<body>
<formname="frm">
<inputtype="radio"name="oper"value="agree">同意</td>
<inputtype="radio"name="oper"value="downchange"checked>下发修改</td>
<inputtype="radio"name="oper"value="refuse">拒保</td>
<inputtype="radio"name="oper"value="report">上报</td>
[br]
alert("result:"+getRadio(this.form.oper))
<inputtype="button"name="test1"value="按钮1">
[br]
alert("result:"+getRadio(document.getElementById("oper")))
<inputtype="button"name="test2"value="按钮2">
[br]
alert(this.form.oper.value)
<inputtype="button"name="test3"value="按钮3">
[br]
changeRadio(this.form.oper,"上报")
<inputtype="button"name="test4"value="按钮4">
[br][br][br][br]
<selectid="slt">
<optionvalue="agree">同意</option>
<optionvalue="downchange"selected>下发修改</option>
<optionvalue="refuse">拒保</option>
<optionvalue="report">上报</option>
</select>
[br]
alert(this.form.slt.value)
<inputtype="button"name="test5"value="按钮5">
[br]
document.getElementById("slt")[2].innerText)
<inputtype="button"name="test6"value="按钮6">
</form>
</body>
</html>