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


Posted in Javascript onMarch 05, 2010

一、获取下拉列表选中项的值和文本(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> 
</html>
Javascript 相关文章推荐
再谈javascript 动态添加样式规则 W3C校检
Dec 25 Javascript
javascript 在firebug调试时用console.log的方法
May 10 Javascript
window.open以post方式将内容提交到新窗口
Dec 26 Javascript
使用javascipt---实现二分查找法
Apr 10 Javascript
js函数在frame中的相互调用详解
Mar 03 Javascript
jquery根据锚点offset值实现动画切换
Sep 11 Javascript
Javascript基础教程之函数对象和属性
Jan 18 Javascript
使用javascript实现判断当前浏览器
Apr 14 Javascript
JavaScript正则替换HTML标签功能示例
Mar 02 Javascript
angularjs+bootstrap菜单的使用示例代码
Mar 07 Javascript
vue实现组件之间传值功能示例
Jul 13 Javascript
vue中data里面的数据相互使用方式
Jun 05 Vue.js
jquery checkbox全选、取消全选实现代码
Mar 05 #Javascript
javascript 隐藏/显示指定的区域附HTML元素【legend】用法
Mar 05 #Javascript
ExtJS 工具栏 分页事件参数
Mar 05 #Javascript
Microsoft Ajax Minifier 压缩javascript的方法
Mar 05 #Javascript
javascript 浏览器检测代码精简版
Mar 04 #Javascript
前端开发部分总结[兼容性、DOM操作、跨域等](持续更新)
Mar 04 #Javascript
jquery与google map api结合使用 控件,监听器
Mar 04 #Javascript
You might like
Mac系统下使用brew搭建PHP(LNMP/LAMP)开发环境
2015/03/03 PHP
js 获取中文拼音,Select自动匹配字母获取值的代码
2009/09/23 Javascript
jquery 弹出层实现代码
2009/10/30 Javascript
JQuery小知识
2010/10/15 Javascript
js hover 定时器(实例代码)
2013/11/12 Javascript
JavaScript作用域链示例分享
2014/05/27 Javascript
JS中使用sort结合localeCompare实现中文排序实例
2014/07/23 Javascript
如何实现chrome浏览器关闭页面时弹出“确定要离开此面吗?”
2015/03/05 Javascript
举例讲解AngularJS中的模块
2015/06/17 Javascript
利用jQuery解析获取JSON数据
2017/04/08 jQuery
jQuery插件FusionCharts绘制2D柱状图和折线图的组合图效果示例【附demo源码】
2017/04/10 jQuery
vue2的todolist入门小项目的详细解析
2017/05/11 Javascript
基于JavaScript实现无限加载瀑布流
2017/07/21 Javascript
vuejs父子组件之间数据交互详解
2017/08/09 Javascript
详解webpack多页面配置记录
2018/01/22 Javascript
webpack下实现动态引入文件方法
2018/02/22 Javascript
vue项目打包部署_nginx代理访问方法详解
2018/09/20 Javascript
支付宝小程序tabbar底部导航
2018/11/06 Javascript
理理Vue细节(推荐)
2019/04/16 Javascript
如何自定义微信小程序tabbar上边框的颜色
2019/07/09 Javascript
Python unittest单元测试框架总结
2018/09/08 Python
PyQt5通信机制 信号与槽详解
2019/08/07 Python
解决python有时候import不了当前的包问题
2019/08/28 Python
python实现的发邮件功能示例
2019/09/11 Python
python 使用while循环输出*组成的菱形实例
2020/04/12 Python
Tensorflow实现将标签变为one-hot形式
2020/05/22 Python
Matplotlib自定义坐标轴刻度的实现示例
2020/06/18 Python
Ted Baker美国官网:英国时尚品牌
2018/10/29 全球购物
行政人员工作职责
2013/12/05 职场文书
高中同学聚会邀请函
2014/01/11 职场文书
高中生的自我鉴定范文
2014/01/24 职场文书
国际经济与贸易专业求职信
2014/07/10 职场文书
民主评议党员个人总结
2015/02/13 职场文书
公司晚宴祝酒词
2015/08/11 职场文书
SSM VUE Axios详解
2021/10/05 Vue.js
Flink 侧流输出源码示例解析
2022/09/23 Servers