JS取得下拉列表与按钮中的值

    

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

Html代码 复制代码
  1. <html>  
  2. <head><title>获取下拉列表选中项的值和文本(select)</title></head>  
  3. <body>  
  4. <script>  
  5.   
  6. //获取下拉列表选中项的文本   
  7. function getSelectedText(name){   
  8. var obj=document.getElementById(name);   
  9. for(i=0;i<obj.length;i++){   
  10.    if(obj[i].selected==true){   
  11.     return obj[i].innerText;      //关键是通过option对象的innerText属性获取到选项文本   
  12.    }   
  13. }   
  14. }   
  15.   
  16. //获取下拉列表选中项的值   
  17. function getSelectedValue(name){   
  18. var obj=document.getElementById(name);   
  19. return obj.value;      //如此简单,直接用其对象的value属性便可获取到   
  20. }   
  21.   
  22. </script>  
  23. <select id="myselect">  
  24. <option value="fist">1</option>  
  25. <option value="second">2</option>  
  26. <option value="third">3</option>  
  27. </select>  
  28.   
  29. <input type="button"   value="所选文本"   onclick="alert(getSelectedText('myselect'));" />  
  30. <input type="button"   value="所选值" onclick="alert( getSelectedValue('myselect'));" />  
  31. </body>  
  32. </html>  
<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="所选文本" οnclick="alert(getSelectedText('myselect'));" /> <input type="button" value="所选值" οnclick="alert( getSelectedValue('myselect'));" /> </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代码 复制代码
  1. <html>  
  2. <head></head>  
  3. <script language="javascript">  
  4.   
  5. //求单选按纽的值,适用单选项及多选项。未选返回false;有选择项,返回选项值。   
  6. function getRadio(oRadio){   
  7. var oRadiooRadioLength= oRadio.length;   
  8. var oRadioValue = false;   
  9. //alert("oRadioLength:["+oRadioLength+"]");   
  10.   
  11. if (oRadioLength== undefined){   
  12.       if (oRadio.checked){   
  13.        oRadiooRadioValue = oRadio.value;   
  14.       }   
  15. }else{   
  16.       for (i=0;i<oRadioLength;i++){   
  17.        //alert("oRadio["+i+"]:"+oRadio[i].checked+"/"+oRadio[i].value);   
  18.        if (oRadio[i].checked){   
  19.         oRadiooRadioValue = oRadio[i].value;   
  20.         break;   
  21.        }   
  22.       }   
  23. }   
  24. return oRadioValue;   
  25. }   
  26.   
  27.   
  28. //方法改进:   
  29.   
  30. //求单选按纽的值,传radio名字作为参数。未选返回false;有选择项,返回选项值。   
  31. function getRadioValue(name){   
  32. var radioes = document.getElementsByName(name);    
  33. for(var i=0;i<radioes.length;i++)   
  34. {   
  35.      if(radioes[i].checked){   
  36.       return radioes[i].value;   
  37.      }   
  38. }   
  39. return false;   
  40. }   
  41.   
  42.   
  43. //通过值修改所选中的单选按钮   
  44. function changeRadio(oRadio,oRadioValue){        //传入一个对象   
  45. for(var i=0;i<oRadio.length;i++) //循环   
  46. {   
  47.         if(oRadio[i].value==oRadioValue) //比较值   
  48.         {    
  49.          oRadio[i].checked=true; //修改选中状态   
  50.          break; //停止循环   
  51.         }   
  52. }   
  53. }   
  54.      
  55.   
  56. //改进:   
  57.   
  58. //通过值修改所选中的单选按钮   
  59. function setRadio(name,sRadioValue){        //传入radio的name和选中项的值   
  60. var oRadio = document.getElementsByName(name);    
  61. for(var i=0;i<oRadio.length;i++) //循环   
  62. {   
  63.         if(oRadio[i].value==sRadioValue) //比较值   
  64.         {    
  65.          oRadio[i].checked=true; //修改选中状态   
  66.          break; //停止循环   
  67.         }   
  68. }   
  69. }   
  70.   
  71. </script>  
  72.   
  73. <body>  
  74. <form name="frm">  
  75.   
  76. <input type="radio" name="oper" value="agree"        >同意</td>  
  77. <input type="radio" name="oper" value="downchange" checked>下发修改</td>  
  78. <input type="radio" name="oper" value="refuse">拒保</td>  
  79. <input type="radio" name="oper" value="report" >上报 </td>  
  80. <br>  
  81. alert('result:'+getRadio(this.form.oper))   
  82. <input type="button" name="test1" value="按钮1" onclick="alert('result:'+getRadio(this.form.oper));">          
  83. <br>  
  84. alert('result:'+getRadio(document.getElementById('oper')))   
  85. <input type="button" name="test2" value="按钮2" onclick="alert('result:'+getRadio(document.getElementById('oper')));">  
  86. <br>  
  87. alert(this.form.oper.value)   
  88. <input type="button" name="test3" value="按钮3" onclick="alert(this.form.oper.value);">  
  89. <br>  
  90. changeRadio(this.form.oper,"上报")   
  91. <input type="button" name="test4" value="按钮4" onclick="changeRadio(this.form.oper,'report');">     
  92. <br><br><br><br>       
  93.   
  94.   
  95. <select id="slt">  
  96. <option value="agree" >同意</option>  
  97. <option        value="downchange" selected>下发修改</option>  
  98. <option value="refuse">拒保</option>  
  99. <option        value="report">上报</option>  
  100. </select>  
  101. <br>  
  102. alert(this.form.slt.value)   
  103. <input type="button" name="test5" value="按钮5" onclick="alert(this.form.slt.value);">  
  104. <br>  
  105. document.getElementById('slt')[2].innerText)   
  106. <input type="button" name="test6" value="按钮6" onclick="alert(document.getElementById('slt')[2].innerText);">  
  107.   
  108.   
  109. </form>  
  110. </body>  
  111. </html>  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值