复选框(checkbox)

1、需求分析

可同时选中多项选项,全选/全不选/反选

2、技术分析

基础的html、CSS、JavaScript

3、详细分析

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

3.2 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;
        }
</style>

3.3 JavaScript部分

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

原文地址:https://www.cnblogs.com/shidingzhang/p/9363291.html

时间: 2024-08-30 09:00:07

复选框(checkbox)的相关文章

css3美化复选框checkbox

css3美化复选框checkbox:http://www.helloweba.com/view-blog-295.html

QTableView中嵌入复选框CheckBox 的四种方法总结

搜索了一下,QTableView中嵌入复选框CheckBox方法有四种: 第一种不能之前显示,必须双击/选中后才能显示,不适用. 第二种比较简单,通常用这种方法. 第三种只适合静态显示静态数据用 第四种比较适合扩展,它除了可以嵌入复选框,还可以通过paint()绘制其它控件,图片等自定义风格. 第一种方法是:编辑委托法 这种方法直接利用委托中重载createEditor(),激活QCheckBox,这个缺点是必须双击/选中,才能显示CheckBox控件.一般不满足我们实际中的直接显示的需要.可以

单选按钮RadioGroup与复选框CheckBox

在AndroidApp应用中,单选按钮和复选框也是经常使用的,下面我们一起学习一下.我们需要学习Android中的基本控件:(1)单选按钮RadioGroup.(2)复选框CheckBox. 一.设计登录窗口 打开"res/layout/activity_main.xml"文件.  1.分别从工具栏向activity拖出1个单选按钮列表RadioGroup(注意自动包含3个单选按钮RadioButton).2个复选框CheckBox.1个按钮Button.这3个控件均来自Form Wi

bootstrap-表单控件——复选框checkbox和单选择按钮radio

1.运行效果如图所示 2.实现代码如下 <!DOCTYPE html> <html> <head>     <meta charset="utf-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <title>表单控件--复选框checkbox和单选择按钮radio</title>

jQuery 操作复选框(checkbox) attr checked不起作用

jQuery 更改checkbox的状态,无效 $(this).attr("checked", false).checkboxradio("refresh");     //应该这么写吧,少了$这个东东~~~跟js混淆了 jQuery 操作复选框(checkbox) attr checked不起作用 这 天用到jQuery功能,想实现一个简单的复选框动态全选或全不选,结果测试发现 attr(‘checked’,'checked’);与attr(‘checked’,t

3.Android之单选按钮RadioGroup和复选框Checkbox学习

单选按钮和复选框在实际中经常看到,今天就简单梳理下. 首先,我们在工具中拖进单选按钮RadioGroup和复选框Checkbox,如图: xml对应的源码: <?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="

3种炫酷CSS3复选框checkbox动画特效

这是一款效果非常炫酷的CSS3复选框checkbox动画特效.这组复选框动画特效共3种效果,它们都是在原生checkbox元素的基础上进行了美化,在用户点击复选框的时候制作出非常酷的动画效果. 在线预览   源码下载 使用方法 HTML结构 普通的HTML checkbox复选框控件的样式非常的平淡.在现代网页设计中,我们可以通过CSS3来为它设置更加漂亮的外观和动画特效.通过CSS的@keyframe属性,我们就可以制作出各种神奇的复选框动画特效. 在这些复选框动画的DEMO中,使用的都是无序

基于CSS3自定义美化复选框Checkbox组合

今天我们要来分享一组非常漂亮的CSS3自定义复选框checkbox,每一个checkbox都有其各自的特点.有几款checkbox在选中的情况下还会出现动画效果,非常不错的CSS3自定义美化checkbox组合.另外,之前分享过的jQuery实现美化版的单选框和复选框也是非常不错. 在线预览   源码下载 实现的代码: <div class="container"> <div class="holder"> <div class=&qu

jquery操作复选框(checkbox)的12个小技巧总结

1.获取单个checkbox选中项(三种写法)$("input:checkbox:checked").val()或者$("input:[type='checkbox']:checked").val();或者$("input:[name='ck']:checked").val(); 2. 获取多个checkbox选中项$('input:checkbox').each(function() {        if ($(this).attr('che

php 判断复选框checkbox是否被选中

php 判断复选框checkbox是否被选中 复选框checkbox在php表单提交中经常被使用到,本文章通过实例向大家介绍php如何判断复选框checkbox中的值是否被选中,需要的朋友可以参考一下本文章的实例. 本文章向大家介绍两个知识点: php表单提交如何获取复选框checkbox的值 php如何判断复选框checkbox中的值是否被选中 下面我们分别对这两个知识点进行讲解: 1.php如何获取复选框checkbox的值 首先我们来创建一个表单: <form action ="Ha