Jquery 操作Html 控件 CheckBox、Radio、Select 控件

本文详细介绍使用JQuery操作HTML控件的方法,包括CheckBox、Radio和Select等常见控件的选择、禁用、取值及选择等功能,并提供大量实用示例。

原文地址:http://www.cnblogs.com/lxblog/archive/2013/01/09/2853056.html

在使用 Javascript 编写前台脚本的时候,经常会操作 Html 控件,比如 checkbox、radio、select,用 Jquery 库操作其他会方便很多,下面用Jq对这些控件的操作进行一个全面的代码总结。

一、Jquery 对 CheckBox 的操作:

<input id="ckb1" name="ckb" checked="checked" value="0" type="checkbox" /><span>篮球</span>
<input id="ckb2" name="ckb" checked="checked" value="1" type="checkbox" /><span>排球</span>
<input id="ckb3" name="ckb" disabled="disabled" value="2" type="checkbox" /><span>乒乓球</span>
<input id="ckb4" name="ckb" disabled="disabled" value="3" type="checkbox" /><span>羽毛球</span>

1、查找控件:

(1) 选择所有的 checkbox  控件:
根据input类型选择: $("input[type=checkbox]")   等同于文档中的 $("input:checkbox")
根据名称选择:$("input[name=ckb]")

(2) 根据索引获取checkbox控件:
$("input:checkbox:eq(1)")
 结果返回:<input id="ckb2" name="ckb" value="1" type="checkbox" /><span>排球</span>

(3) 获得所有禁用的 checkbox 控件:
$("input[type=checkbox]:disabled") 
结果返回:
<input id="ckb3" name="ckb" disabled="disabled" value="2" type="checkbox" /><span>乒乓球</span>
<input id="ckb4" name="ckb" disabled="disabled" value="3" type="checkbox" /><span>羽毛球</span>
 

(4)获得所有启用的checkbox控件
$("input:checkbox[disabled=false]")
结果返回:
<input id="ckb1" name="ckb" checked="checked" value="0" type="checkbox" /><span>篮球</span>
        <input id="ckb2" name="ckb" checked="checked" value="1" type="checkbox" /><span>排球</span> 

(5)获得所有checked的checkbox控件
$("input:checkbox:checked") 
结果返回:
<input id="ckb1" name="ckb" checked="checked" value="0" type="checkbox" /><span>篮球</span>
        <input id="ckb2" name="ckb" checked="checked" value="1" type="checkbox" /><span>排球</span> 

(6)获取所有未checkd的checkbox控件
$("input:checkbox:[checked=false]") 
结果返回:
<input id="ckb3" name="ckb" disabled="disabled" value="2" type="checkbox" /><span>乒乓球</span>
        <input id="ckb4" name="ckb" disabled="disabled" value="3" type="checkbox" /><span>羽毛球</span> 

(7)获得value 为 0 的checkbox 控件
$("input[type=checkbox][value=0]")
结果返回:
<input id="ckb1" name="ckb" checked="checked" value="0" type="checkbox" /><span>篮球</span>

2、禁用:

(1)禁用所有的checkbox控件:
$("input:checkbox").attr("disabled", true) 

(2)启用某些禁用的 checkbox 控件:
$("input:checkbox:disabled").attr("disabled", false); 

(3)判断value=0的checkbox是否禁用:
    if ($("input[name=ckb][value=0]").attr("disabled") == true) {
          alert("不可用");
    }
   else {
         alert("可用");
    }

3、选择: 

(1)全选:
$("input:checkbox").attr("checked", true);

(2)全不选:
$("input:checkbox").attr("checked", false); 

(3)反选:
   $("input:checkbox").each(function () {
      if ($(this).attr("checked")) {
        //$(this).removeAttr("checked");
        $(this).attr("checked", false);
     }
     else {
       $(this).attr("checked",true);
    }
  });

4、取值:   

  function GetCkboxValues() {
    var str="";
   $("input:checkbox:checked").each(function () {
     switch ($(this).val()) {
      case "0":
             str += "篮球,";
             break;
     case "1":
             str += "排球,";
      break;
     case "2":
             str += "乒乓球,";
             break;
     case "3":
            str += "羽毛球,";
            break;
     }
   });
   str=str.substring(0, str.length - 1)
  }

二、Jquery 对 Radio 的操作:

<input name="edu" value="0" type="radio" checked="checked" /><span>专科</span>
<input name="edu" value="1" type="radio" /><span>本科</span>
<input name="edu" value="2" type="radio" disabled="disabled" /><span>研究生</span>
<input name="edu" value="3" type="radio" disabled="disabled"/><span>博士生</span>

  1、查找控件:

(1)选择所有的 Radio控件
//根据input类型选择
$("input[type=radio]")  //等同于文档中的 $("input:radio")
//根据名称选择
$("input[name=edu]")

(2)根据索引获得 Radio控件
$("input:radio:eq(1)")
结果返回:<input name="edu" value="1" type="radio" /><span>本科</span>

(3)获得所有禁用的 Radio 控件
$("input:radio:disabled")
结果返回:
<input name="edu" value="2" type="radio" disabled="disabled" /><span>研究生</span>
        <input name="edu" value="3" type="radio" disabled="disabled"/><span>博士生</span>

(4)获得所有启用的 Radio 控件
$("input:radio[disabled=false]")
结果返回:
<input name="edu" value="0" type="radio" checked="checked" /><span>专科</span>
        <input name="edu" value="1" type="radio" /><span>本科</span>

(4)获得checked的 RadioButton 控件
$("input:radio:checked") //等同于 $("input[type=radio][checked]")
结果返回:
<input name="edu" value="0" type="radio" checked="checked" /><span>专科</span>

(5)获取未checked的 RadioButton 控件
$("input:radio[checked=false]").attr("disabled", true);
结果返回:
<input name="edu" value="1" type="radio" /><span>本科</span>
        <input name="edu" value="2" type="radio" disabled="disabled" /><span>研究生</span>
        <input name="edu" value="3" type="radio" disabled="disabled"/><span>博士生</span>

(6)获得value 为 0 RadioButton 控件
$("input[type=radio][value=0]")
结果返回:<input name="edu" value="0" type="radio" checked="checked" /><span>专科</span>

2、禁用: 

(1)禁用所有的Radio
$("input:radio").attr("disabled", true);
或者 $("input[name=edu]").attr("disabled", true); 

(2)禁用索引为1的Radio控件
$("input:radio:eq(1)").attr("disabled", true); 

(3)启用禁用的Radio控件
$("input:radio:disabled").attr("disabled", false); 

(4)禁用当前已经启用的Radio控件
$("input:radio[disabled=false]").attr("disabled", true); 

(5)禁用 checked 的RadioButton控件
$("input[type=radio][checked]").attr("disabled", true); 

(6)禁用未checked 的RadioButton控件
$("input:[type=radio][checked=false]").attr("disabled", true); 

(7)禁用value=0 的RadioButton
$("input[type=radio][value=0]").attr("disabled", true); 

3、取值:

$("input:radio:checked").val()

4、选择:

(1)判断value=1 的radio控件是否选中,未选中则选中:
  var v = $("input:radio[value=1]").attr("checked");
  if (!v) {
  $("input:radio[value=1]").attr("checked", true);
  } 

(2)转换成Dom元素数组来进行控制选中:
$("input:radio[name=edu]").get(1).checked = true;

三、Jquery 对 Select 操作

复制代码
<select id="cmbxGame">
   <option value="0" selected="selected">黑猫警长</option>
   <option value="1" disabled="disabled">大头儿子</option>
   <option value="2">熊出没</option>
   <option value="3">喜羊羊</option>
</select>
复制代码

 1、禁用:

(1)禁用select 控件
$("select").attr("disabled", true);

(2)禁用select中所有option
$("select option").attr("disabled", true);

(3)禁用value=2 的option
$("select option[value=2]").attr("disabled", true);

(4)启用被禁用的option
$("select option:disabled").attr("disabled", false);

2、选择:

(1)option 值为 2 的被选择:
  var v = $("select option[value=2]").attr("selected");
  if (!v) {
  $("select option[value=2]").attr("selected", true);
  }

(2) 索引为 2 的option 项 被选择
$("select")[0].selectedIndex = 2;
或者 $("select").get(0).selectedIndex = 2; 
或者 $("select option[index=2]").attr("selected", true);

3、获取选择项的索引: 

(1)获取选中项索引: jq 中的 get 函数是将jq对象转换成了dom元素
 var selectIndex = $("select").get(0).selectedIndex;
或者 var selectIndex = $("select option:selected").attr("index");

(2)获取最大项的索引:
var maxIndex = $("select option:last").attr("index")
或者  var maxIndex = $("select option").length - 1

4、删除select 控件中的option 

(1)清空所有option
$("select option").empty(); 

(2)删除 value=2 的option
$("select option[value=2]").remove(); 

(3)删除第一个option
$("select option[index=0]").remove(); 

(4)删除 text="熊出没" 的option
$("select option[text=熊出没]").remove();  //此方法某些浏览器不支持用下面的方法替代

注意:each 中不能用break 用return false 代替,continue 用 return true 代替
$("select option").each(function () {
  if ($(this).text() == "熊出没") {
  $(this).remove();
  return false;
  }
    });

5、在select中插入option 

(1)在首位置插入 option 并选择
$("select").prepend("<option value='0'>请选择</option>");
$("select option[index=0]").attr("selected", true); 

(2)在尾位置插入 option 并选择
$("select").append("<option value=\"5\">哪吒闹海</option>");
var maxIndex = $("select option:last").attr("index")
$("select option[index=" + maxIndex + "]").attr("selected", true); 

(3)在固定位置插入 比如第一个option 项之后插入 新的option 并选择
$("<option value=\"5\">哪吒闹海</option>").insertAfter("select option[index=0]");
或者$("select option[index=0]").after("<option value=\"5\">哪吒闹海</option>");
    $("select option[index=1]").attr("selected", true);

6、取值:

  function GetCbxSelected() {
    var v = $("select option:selected").val();
    var t = $("select option:selected").text();
    alert("值:" + v + "文本:" + t);
}

 

基于51单片机,实现对直流电机的调速、测速以及正反转控制。项目包含完整的仿真文件、源程序、原理图和PCB设计文件,适合学习和实践51单片机在电机控制方面的应用。 功能特点 调速控制:通过按键调整PWM占空比,实现电机的速度调节。 测速功能:采用霍尔传感器非接触式测速,实时显示电机转速。 正反转控制:通过按键切换电机的正转和反转状态。 LCD显示:使用LCD1602液晶显示屏,显示当前的转速和PWM占空比。 硬件组成 主控制器:STC89C51/52单片机(与AT89S51/52、AT89C51/52通用)。 测速传感器:霍尔传感器,用于非接触式测速。 显示模块:LCD1602液晶显示屏,显示转速和占空比。 电机驱动:采用双H桥电路,控制电机的正反转和调速。 软件设计 编程语言:C语言。 开发环境:Keil uVision。 仿真工具:Proteus。 使用说明 液晶屏显示: 第一行显示电机转速(单位:转/分)。 第二行显示PWM占空比(0~100%)。 按键功能: 1键:加速键,短按占空比加1,长按连续加。 2键:减速键,短按占空比减1,长按连续减。 3键:反转切换键,按下后电机反转。 4键:正转切换键,按下后电机正转。 5键:开始暂停键,按一下开始,再按一下暂停。 注意事项 磁铁和霍尔元件的距离应保持在2mm左右,过近可能会在电机转动时碰到霍尔元件,过远则可能导致霍尔元件无法检测到磁铁。 资源文件 仿真文件:Proteus仿真文件,用于模拟电机控制系统的运行。 源程序:Keil uVision项目文件,包含完整的C语言源代码。 原理图:电路设计原理图,详细展示了各模块的连接方式。 PCB设计:PCB布局文件,可用于实际电路板的制作。
【四旋翼无人机】具备螺旋桨倾斜机构的全驱动四旋翼无人机:建模与控制研究(Matlab代码、Simulink仿真实现)内容概要:本文围绕具备螺旋桨倾斜机构的全驱动四旋翼无人机展开研究,重点进行了系统建模与控制策略的设计与仿真验证。通过引入螺旋桨倾斜机构,该无人机能够实现全向力矢量控制,从而具备更强的姿态调节能力和六自由度全驱动特性,克服传统四旋翼欠驱动限制。研究内容涵盖动力学建模、控制系统设计(如PID、MPC等)、Matlab/Simulink环境下的仿真验证,并可能涉及轨迹跟踪、抗干扰能力及稳定性分析,旨在提升无人机在复杂环境下的机动性与控制精度。; 适合人群:具备一定控制理论基础和Matlab/Simulink仿真能力的研究生、科研人员及从事无人机系统开发的工程师,尤其适合研究先进无人机控制算法的技术人员。; 使用场景及目标:①深入理解全驱动四旋翼无人机的动力学建模方法;②掌握基于Matlab/Simulink的无人机控制系统设计与仿真流程;③复现硕士论文级别的研究成果,为科研项目或学术论文提供技术支持与参考。; 阅读建议:建议结合提供的Matlab代码与Simulink模型进行实践操作,重点关注建模推导过程与控制器参数调优,同时可扩展研究不同控制算法的性能对比,以深化对全驱动系统控制机制的理解。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值