javascript事件案例-全选框案例

这里要求全选框是点中全选框,下面的复选框自动选中,再点击就取消选中。

如果下面复选框都选中,则上面全选框自动选中

思路:

复选框的checked的值是布尔类型,选中是true,没选是false

如果全选的checked的值变为什么,则下面复选框的checked值同步变为什么。

要实现下面复选框选中,则全选自动选中,可以假设全选先被选中,再检查复选框,只要有一个没有选中,则全选就取消选中

先制作复选框与全选的html案例

html 复制代码
    <table id="tbl">
        <thead>
            <tr>
                <th>全选:<input type="checkbox" name="" id="all"></th>
                <th>序号</th>
                <th>姓名</th>
                <th>年龄</th>
                <th>性别</th>
                <th>爱好</th>
            </tr>
        </thead>
        <tbody>
            <tr>
                <td><input type="checkbox" name="item"></td>
                <td>1</td>
                <td>tom</td>
                <td>age</td>
                <td>meal</td>
                <td>eat</td>
            </tr>
            <tr>
               <td><input type="checkbox" name="item"></td>
                <td>2</td>
                <td>jack</td>
                <td>age</td>
                <td>meal</td>
                <td>eat</td>
            </tr>
            <tr>
                <td><input type="checkbox" name="item"></td>
                <td>3</td>
                <td>alic</td>
                <td>age</td>
                <td>meal</td>
                <td>eat</td>
            </tr>
            <tr>
                <td><input type="checkbox" name="item"></td>
                <td>4</td>
                <td>mike</td>
                <td>age</td>
                <td>meal</td>
                <td>eat</td>
            </tr>
        </tbody>
    </table>

css效果代码

css 复制代码
 #tbl {
            width: 500px;
            height:200px;
            margin:0 auto;
            border-collapse: collapse;
        }
        td,th{
            border:1px solid #ccc;
        }

        tbody tr{
            text-align: center;
        }

效果如下图

javascript代码如下

javascript 复制代码
window.onload=function()
        {
        //全选框被选中,下面复选框一起选中,反之,全选框取消,复选框也取消选择
            let all=document.getElementById("all")
            all.onchange=function()
            {
                let items=document.getElementsByName("item")
                for(let item of items)
               {
                item.checked=this.checked
               }
            }
            //当下面复选框都被选中,则实现全选被选中
            let items=document.getElementsByName("item")
            for(let item of items)
            {
                item.onchange=function()
                {
                    //先假定全选被选中,只要有一个没有被选中,全选就取消
                    all.checked=true
                    for(let item of items)
                    {
                        if(!item.checked)
                       {
                        all.checked=false
                        break
                       }
                    }
                }
            }

        }
相关推荐
Dillon Dong2 小时前
【系列主题】Next.js 16 + Turbopack 的暗礁:深入剖析 Tailwind v4 的 CSS 模块解析陷阱
javascript·css·容器·turbopack
Csvn2 小时前
前端性能优化实战指南
前端
Moment2 小时前
2026 年,AI 全栈时代到了,前端简历别再只写前端技术了 🫠🫠🫠
前端·后端·面试
糯米团子7492 小时前
Web Worker
开发语言·前端·javascript
freewlt3 小时前
React Server Components 深度解析
前端·react.js·前端框架
wordbaby3 小时前
一次跨端 Loading 卡死复盘:把请求计数从 Axios 拦截器迁到 try/catch/finally
前端·axios
我命由我123453 小时前
JavaScript 开发 - 获取函数名称、获取函数参数数量、获取函数参数名称
开发语言·前端·javascript·css·html·html5·js
IT_陈寒4 小时前
JavaScript里这个隐式类型转换的坑,我终于爬出来了
前端·人工智能·后端
狂奔的sherry4 小时前
一次由 mount 引发的 Linux 文件系统“错觉”
linux·运维·服务器