html 多选框

🌙
手机阅读
本文目录结构

html 多选框

核心代码

<input type="checkbox" />

定义和用法

checked 属性规定在页面加载时应该被预先选定的 input 元素。

checked 属性 与 <input type="checkbox"><input type="radio"> 配合使用。

checked 属性也可以在页面加载后,通过 JavaScript 代码进行设置。

需求分析

可同时选中多个选项,实现全选、全不选、反选等功能。

技术分析

基础的 HTML、CSS、JavaScript。

HTML 部分

图示是一个列表加底部一段文字说明,列表包含三个部分,整体是一个多选列表,上部是总的选项,下面是具体选项,因此该列表是一个自定义列表:

<body>
    <dl class="checkBox">
        <dt><input type="checkbox" id="checkAll">
            <label>全选</label>
            /*给"反选"建立js链接,实现动态效果*/
            <a href="javascript:;">反选</a>
        </dt>
        <dd>
            /*选项由选择框(输入框)和标示构成,所以使用<input>标签和<label>标签,label 元素不会呈现任何特殊效果。如果在 label 元素内点击文本,就会触发此控件*/
            <p><input type="checkbox" name="item"><label>选项1</label></p>
            <p><input type="checkbox" name="item"><label>选项2</label></p>
            <p><input type="checkbox" name="item"><label>选项3</label></p>
            <p><input type="checkbox" name="item"><label>选项4</label></p>
            <p><input type="checkbox" name="item"><label>选项5</label></p>
            <p><input type="checkbox" name="item"><label>选项6</label></p>
            <p><input type="checkbox" name="item"><label>选项7</label></p>
            <p><input type="checkbox" name="item"><label>选项8</label></p>
        </dd>
    </dl>
    <center>1、切换全选全不选文字2、根据选中个数更新全选框状态</center>
</body>

CSS

<style type="text/css">
/*浏览器格式化,消除页面预留空间*/
    *{
        margin: 0;
        padding: 0;
       }
        /*适应各种浏览器屏幕尺寸*/
    body{
        width: 100%;
        height: 100%;
        /*设置页面字体大小*/
        font-size: 14px;
        }
    /*列表内元素垂直居中*/
    label,input,a{vertical-align:middle;}
    /*给选项表示设置内边距*/
    label{padding:0 10px 0 5px;}
    /*给列表设置边框*/
    dl{
         width: 120px;
         /*元素水平居中*/
         margin: 10px auto;
         border: 1px solid #666;
         /*设置边框圆角*/
         border-radius: 5px;
         background: #fafafa;
         padding: 10px 5px;
        }
    /*消除链接下划线,设置链接字体颜色*/
    a{
         text-decoration: none;
         color: #09f;
        }
    /*鼠标指针浮动在链接上时,样式改变:字体变红色*/
    a:hover{
         color: red;
        }
    dt{
         /*下边框*/
         border-bottom: 1px solid black;
         /*距离底部内边距*/
         padding-bottom: 10px;
        }
        /*标示字体加粗*/
    dt label{
         font-weight: 700;
        }
        /*各个选项距离顶部外边距*/
    p{
         margin-top: 10px;
        }<br></style>

JS 部分

<script type="text/javascript">
    window.onload=function(){//网页加载完成后调用函数
        var oA=document.getElementsByTagName("a")[0];//获取第一个a元素,即链接"反选"
        var oInput=document.getElementsByTagName("input");//获取所有的输入选择框
        var oLabel=document.getElementsByTagName("label")[0];//获取第一个lable标签,lable标签为input标签定义标记,即"全选"选项。
        var isCheckAll=function( ){//声明一个全选函数
              for(var i=1,n=0;i<oInput.length;i++){//从i=1循环,排除第一个选项"全选“,从选项1开始循环。
                    oInput[i].checked && n++//没选择一个选项,则n增加1,n=已选的项目数
                }
                    oInput[0].checked=n==oInput.length-1;//选择第一个选项=选择第一个项目之外的全部选项,所以点击全选的同时,其他所有选项一并选中。
                    oLabel.innerHTML = oInput[0].checked ? "全不选" : "全选"//innerHtml改变第一个标签"全选'的元素内容,后面为判断语句:选择"全选"时,全选变为全不选,
否则为全选。
            };
            oInput[0].onclick=function(){//给第一个选项"全选"绑定点击函数事件,点击全选时,执行函数
                  for(var i=1;i<oInput.length;i++){
                    oInput[i].checked=this.checked//当点击第一个"全选"选项时,执行循环函数:遍历选择每个选项,即点击全选时,所有选项都选择,实现全选,同理实现全不选,
这里的this即为oInput[0],将第一个input的checked值赋给每一个input元素。
                }
                isCheckAll()
            };
            oA.onclick=function(){//给"反选"绑定点击事件,当点击反选时,执行相应函数事件
                for (var i = 1; i < oInput.length; i++){
                    oInput[i].checked=!oInput[i].checked//点击反选,已选变未选,未选变已选,!为否定
                };
            }
                for (var i = 1; i < oInput.length; i++) {//点击改变元素
                    oInput[i].onclick=function(){
                        isCheckAll()//oLabel.innerHTML = oInput[0].checked ? "全不选" : "全选",根据选中个数更新全选框状态,当全选后,全选切换为全不选。
                    };
                }

            }
</<script>

更多 HTML 搜索

通过查看前端开发者在搜索引擎里的搜了哪些 HTML 内容,可以知道他们实际工作使用了什么技术或者什么地方薄弱;

你可以通过点击 HTML 常见搜索 来查看前端开发者都在搜哪些内容;

注:这里仅收录了常见搜索,并不是无论搜索什么都记录在里面的;

如果你是为了面试做准备的,那么推荐你查看 HTML面试题,这里基本包涵了市场上的所有 HTML 方面的面试题,让你更加牢固的掌握 HTML 知识

AXIHE / 精选资源

浏览全部教程

面试题

学习网站

前端培训
自己甄别

前端书籍

关于朱安邦

我叫 朱安邦,阿西河的站长,在杭州。

以前是一名平面设计师,后来开始接接触前端开发,主要研究前端技术中的JS方向。

业余时间我喜欢分享和交流自己的技术,欢迎大家关注我的 Bilibili

关注我: Github / 知乎

于2021年离开前端领域,目前重心放在研究区块链上面了

我叫朱安邦,阿西河的站长

目前在杭州从事区块链周边的开发工作,机械专业,以前从事平面设计工作。

2014年底脱产在老家自学6个月的前端技术,自学期间几乎从未出过家门,最终找到了满意的前端工作。更多>

于2021年离开前端领域,目前从事区块链方面工作了