• js获取下拉列表选中项的值和文本(select)以及获取单选按钮(radio)组的值和修改选中项
    时间:2008-12-23   作者:佚名   出处:互联网

    一、获取下拉列表选中项的值和文本(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="所选文本"   onclick="alert(getSelectedText('myselect'));" />
    <input type="button"   value="所选值" onclick="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>
    <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" onclick="alert('result:'+getRadio(this.form.oper));">       
    <br>
    alert('result:'+getRadio(document.getElementById('oper')))
    <input type="button" name="test2" value="按钮2" onclick="alert('result:'+getRadio(document.getElementById('oper')));">
    <br>
    alert(this.form.oper.value)
    <input type="button" name="test3" value="按钮3" onclick="alert(this.form.oper.value);">
    <br>
    changeRadio(this.form.oper,"上报")
    <input type="button" name="test4" value="按钮4" onclick="changeRadio(this.form.oper,'report');">  
    <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" onclick="alert(this.form.slt.value);">
    <br>
    document.getElementById('slt')[2].innerText)
    <input type="button" name="test6" value="按钮6" onclick="alert(document.getElementById('slt')[2].innerText);">


    </form>
    </body>

    =============================================================================

    网友留言/评论

    我要留言/评论

    相关文章

    写出漂亮代码的七种方法:首先我想说明我本文阐述的是纯粹从美学的角度来写出代码,而非技术、逻辑等。以下为写出漂亮代码的七种方法:
    Raid的学习和基础知识:各种意外灾难、错误带来的数据损坏和丢失给人们带来的损失和不便,个人及网站服务器的数据必须要备份,作Raid便是一种可行而有效的方法。Raid分为软Raid和硬raid......
    软RAID 0的技术概要及实现:Software RAID 中译是软RAID ,软RAID 比如常用的有RAID 0 、RAID 1 、RAID 5、RAID 10 ;本文主要讲述RAID 0、1、5、10的基本概念及软RAID 的创建、修复和管理;
    基于JSON的高级AJAX开发技术详解:AJAX已经成为当今Web开发中一种强有力的用户交互技术,但是它的许多可能性应用仍然鲜为人知。在本文中,我们将来共同探讨如何使用 JavaScript对象标志(JSON)和JSON分析器在服务器和客户端AJAX引擎之间创建复杂而强有力的JSON数据传输层。我们将详细讨论如何 创建一组对象(在其它语言中经常被当作一个包),如何把这些对象串行化为JSON以发送到服务器端,以及如何把服务器端JSON反串行化为客户端 JavaScript对象。