• js 获取服务器控件的值


    js 获取服务器控件的值

    一、获取下拉列表选中项的值和文本(select)
    代码 select.htm 示例如下:
    =============================================================================
    <html>
    <head><title>
    获取下拉列表选中项的值和文本
    (select)</title></head>
    <body>
    <script>
    //
    获取下拉列表选中项的文本

    function getSelectedText(name){
    var obj=document.getElementByIdx(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(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.getElementByIdx("oper").value,虽然跟单选按钮组一样的下拉列表(也是列表项的数组)也是一个数组,用这种方式可以获到下拉列表的值,但是单选按钮组却获不到所选的值。仔细研究了下,总结如下:
    与下拉列表不同,单选按钮须用this.form.oper或者document.getElementsByName('oper')方式获取该数组对象,document.getElementByIdx('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){      
    //传入radioname和选中项的值
    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.getElementByIdx('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.getElementByIdx('slt')[2].innerText)
    <input type="button" name="test6" value="
    按钮
    6" >

    </form>
    </body>

     

    js怎么取得label的值

    <label id="cvc">Label的值</label>

    <script type=text/javascript>
    alert(cvc.innerHTML);
    </script>

    js 获取 asp.net 服务器端控件 Label TextBox RadioButtonList DropDownList 的值

    在做 BS架构的项目时,经常遇到需要用js 来调用 asp.net 服务器端控件的值。

    大多数的控件他的值都可以通过js调用它的 value属性来获得此控件的值,但是也有例外的情况。

    经常用的 Label控件。他的值用js就不能通过value属性来获得。

       Label控件 js获取的实例, var text= document.getElementByIdx('Label1').innerText;

    假如,这样 var text= document.getElementByIdx('Label1').value; text Undefined

    TextBox 的值就可以 var text= document.getElementByIdx('TextBox 1').value;

    对于,RadioButtonList DropDownList 他们的获取方式是大不一样的!这主要是因为他们所生成的 html元素不一样。

    DropDownList 的值获取比较简单:

            var ddlvalue = document.getElementByIdx('ctl00_Contentplaceholder3_ddlFolws').value;
           

    RadioButtonList 的值获取就比较麻烦:

            var value = "";

            var Result = document.getElementsByName('ctl00$Contentplaceholder3$rblResult');
            for (var i = 0; i < Result.length; i++) {
                if (Result.item(i).checked) {
                    value = Result.item(i).value;
                }
            }

    如果 RadioButtonList 控件没有一个选择的那么 value的值为空!

    对于其他控件 js获取值的方法以后在讨论。

     

  • 相关阅读:
    增长思维——模式&&组织
    BackUP
    增长思维——机会
    Android
    增长思维——作战地图
    Server架构 小知识
    Server
    产品思维——创新模式
    产品思维——用户体验
    博客迁移到~http://zhulingyu.com
  • 原文地址:https://www.cnblogs.com/liaoshiyong/p/3150919.html
Copyright © 2020-2023  润新知