js 获取服务器控件的值

本文详细介绍了如何使用JS获取服务器控件的值,包括下拉列表、单选按钮组、Label控件等,提供了具体示例代码,并对获取过程中的注意事项进行了总结。
一、获取下拉列表选中项的值和文本(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){       //传入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.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获取值的方法 以后在讨论。

具有多种最大功率点跟踪(MPPT)方法的光伏发电系统(P&O-增量法-人工神经网络-模糊逻辑控制-粒子群优化)之使用粒子群算法的最大功率点追踪(MPPT)(Simulink仿真实现)内容概要:本文介绍了一个涵盖多个科研领域的综合性MATLAB仿真资源集合,重点聚焦于光伏发电系统中基于粒子群优化(PSO)算法的最大功率点追踪(MPPT)技术的Simulink仿真实现。文档还列举了多种MPPT方法(如P&O、增量电导法、神经网络、模糊逻辑控制等),并展示了该团队在电力系统、智能优化算法、机器学习、路径规划、无人机控制、信号处理等多个方向的技术服务能力与代码实现案例。整体内容以科研仿真为核心,提供大量可复现的Matlab/Simulink模型和优化算法应用实例。; 适合人群:具备一定电力电子、自动控制或新能源背景,熟悉MATLAB/Simulink环境,从事科研或工程仿真的研究生、科研人员及技术人员。; 使用场景及目标:①学习并实现光伏系统中基于粒子群算法的MPPT控制策略;②掌握多种智能优化算法在电力系统与自动化领域的建模与仿真方法;③获取可用于论文复现、项目开发和技术攻关的高质量仿真资源。; 阅读建议:建议结合提供的网盘资料,按照研究方向选取对应模块进行实践,重点关注Simulink模型结构与算法代码逻辑的结合,注重从原理到仿真实现的全过程理解,提升科研建模能力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值