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
                       }
                    }
                }
            }

        }
相关推荐
豹哥学前端17 分钟前
事件循环(Event Loop)深度解析:让你彻底搞懂 JS 的执行顺序
前端·javascript·面试
竹林81821 分钟前
用 wagmi v2 + Next.js 14 搞 NFT 交易市场前端:从合约调用失败到顺利上架,我踩了哪些坑
javascript·next.js
前端不开发30 分钟前
用一个 Bookmarklet(书签脚本),给任意网页挂一个可拖拽悬浮窗
前端·javascript
接着奏乐接着舞1 小时前
【无标题】
开发语言·前端·javascript
Ian在掘金1 小时前
SSE 还是 WebSocket?从 AI 流式输出聊到实时通信选型
前端·人工智能
雨雨雨雨雨别下啦1 小时前
心理健康AI助手 - 项目总结
前端·javascript·vue.js·人工智能·信息可视化
PILIPALAPENG1 小时前
第4周 Day 3:多 Agent 协作——让 Agent 们"组队干活"
前端·人工智能·python
小江的记录本1 小时前
【Java基础】核心关键字:final、static、volatile、synchronized、transient(附《思维导图》+《面试高频考点清单》)
java·前端·数据结构·后端·ai·面试·ai编程