jquert结合原生javascript实现的checkbox全选与全不选

之所以要使用原生javascript,是因为jQuery的attr方法在这里不能实现,具体是怎么样的,我也不知道。

html代码:

<input type="checkbox" id="checkAll">
<input id="staffItem1" type="checkbox">
<input id="staffItem2" type="checkbox">
<input id="staffItem3" type="checkbox">
<a href="javascript:void(0);" id="checkAllOperation">全部选定</a>
<a href="javascript:void(0);"  id="cancleAllOperation">全部取消</a>

javascript代码:

得保证加载了jquery

     $(document).ready(function () {
        //全选或全不选 
        $("#checkAll").click(function () {
          var flag = document.getElementById('checkAll').checked;//判断全选按钮的状态,用jQuery不行
          var length = $("[id^='staffItem']").length;
          for (var i = 1; i < (length + 1); i ++) {
            document.getElementById('staffItem' + i).checked = flag;
          }
        }); 
        //如果全部选中勾上全选框,全部选中状态时取消了其中一个则取消全选框的选中状态 
        $("[id^='staffItem']").each(function(){ 
          $(this).click(function () {
            if ($("[id^='staffItem']:checked").length == $("[id^='staffItem']").length) { 
              document.getElementById('checkAll').checked = true;
            } else {
              document.getElementById('checkAll').checked = false;
            }
          });
        });
        //全部选定
        $("#checkAllOperation").click(function(){
          document.getElementById('checkAll').checked = true;
          var length = $("[id^='staffItem']").length;
          for (var i = 1; i < (length + 1); i ++) {
            document.getElementById('staffItem' + i).checked = true;
          }
        });
        //全部取消
        $("#cancleAllOperation").click(function(){
          document.getElementById('checkAll').checked = false;
          var length = $("[id^='staffItem']").length;
          for (var i = 1; i < (length + 1); i ++) {
            document.getElementById('staffItem' + i).checked = false;
          }
        });
      });


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值