demo3 表单全选 、全消 实现

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        table {
            width: 600px;
            margin: 100px auto;
            text-align: center;
            border-collapse: collapse;
            font-size: 14px;
        }

        thead tr {
            height: 30px;
            background-color: skyblue;
        }

        thead th {
            border: 1px solid #ccc;
        }

        tbody tr {
            height: 30px;
        }

        tbody td {
            border: 1px solid #ccc;
            font-style: 12px;
            color: blue;
        }
    </style>
</head>

<body>
    <div class="wrap">
        <table>
            <thead>
                <tr>
                    <th>
                        <input type="checkbox" id="j_cbAll">
                    </th>
                    <th>商品</th>
                    <th>价格</th>
                </tr>
            </thead>
            <tbody id="j_tb">
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>iPhone8</td>
                    <td>8000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>iPhone8</td>
                    <td>8000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>iPhone8</td>
                    <td>8000</td>
                </tr>
                <tr>
                    <td>
                        <input type="checkbox">
                    </td>
                    <td>iPhone8</td>
                    <td>8000</td>
                </tr>
            </tbody>
        </table>
    </div>
    <script>
        // 全选 取消:让下面所有复选框的checkbox属性(选中)跟随 全选按钮
        //全选按钮
        let j_cbAll = document.getElementById('j_cbAll')
        // 下面所有复选框
        let j_tbs = document.getElementById('j_tb').getElementsByTagName('input')
        j_cbAll.onclick = function () {
            // this.checked 可以得到当前复选框的选中状态,若是true,即选中,false 未选中
            // console.log(this.checked);
            for (let i = 0; i < j_tbs.length; i++) {
                j_tbs[i].checked = this.checked
            }
        }
        // 下面复选框需要全部选中,上面才能选中做法:给下面复选框都绑定点击事件
        for (let i = 0; i < j_tbs.length; i++) {
            j_tbs[i].onclick = function () {
                // flag控制全选按钮是否选中
                let flag = true
                // 每次点击下面的复选框都要循环检查小按钮是否全被选中
                for (let i = 0; i < j_tbs.length; i++) {
                    if (!j_tbs[i].checked) {
                        flag = false
                        // 退出for循环 可以提高执行效率 只要一个没选中,剩下的无需循环
                        break
                    }
                }
                j_cbAll.checked = flag
            }
        }
    </script>
</body>

</html>

点击全选:

存在未选中时,则全选未选中

另:

<script>
    let checkAll = document.querySelector('#checkAll')
    let cks = document.querySelectorAll('.ck')
    let all = document.querySelector('.all')
    // console.log(all);
    // 全选
    checkAll.addEventListener('click', function () {
      let flag = checkAll.checked
      for (let i = 0; i < cks.length; i++) {
        cks[i].checked = flag
      }
      if (flag) {
        all.innerHTML = '取消'
      } else {
        all.innerHTML = '全选'
      }
    })

    // 列表存在未选中,则全选未选中;列表全选中,则全选 
    // 列表中 每个复选框选中的数量 = 复选框的总个数
    for (let i = 0; i < cks.length; i++) {
      cks[i].addEventListener('click', function () {
        // 复选框的总个数
        let len1 = cks.length
        // 列表中 每个复选框选中的数量
        let len2 = document.querySelectorAll('.ck:checked').length
        // 判断
        if (len1 === len2) {
          checkAll.checked = true
          all.innerHTML = '取消'
        } else {
          checkAll.checked = false
          all.innerHTML = '全选'
        }
      })
    }
</script>

 


版权声明:本文为lryh_原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。