全选反选

全选和反选功能,在开发中可以说是应用得非常多的,以下通过案例分解,学习如何使用JS实现全选反选功能。

该功能可分为如下三大步骤:

1、全选

1.1 获取父checkbox,注册点击事件

1.2 获取所有的子checkbox,让所有子checkbox的状态跟父checkbox保持一致

html和css代码

<style>
* {
padding: 0;
margin: 0;
} .wrap {
width: 300px;
margin: 100px auto 0;
} table {
border-collapse: collapse;
border-spacing: 0;
border: 1px solid #c0c0c0;
width: 300px;
} th,
td {
border: 1px solid #d0d0d0;
color: #404060;
padding: 10px;
} th {
background-color: #09c;
font: bold 16px "微软雅黑";
color: #fff;
} td {
font: 14px "微软雅黑";
} tbody tr {
background-color: #f0f0f0;
} tbody tr:hover {
cursor: pointer;
background-color: #fafafa;
}
</style> <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>小米Mix2s</td>
<td>3000</td>
</tr>
<tr>
<td>
<input type="checkbox"/>
</td>
<td>华为P30</td>
<td>3800</td>
</tr>
<tr>
<td>
<input type="checkbox"/>
</td>
<td>iPad Air</td>
<td>2000</td>
</tr>
<tr>
<td>
<input type="checkbox"/>
</td>
<td>小米手环</td>
<td>200</td>
</tr> </tbody>
</table>
<input type="button" value=" 反 选 " id="btn">
</div>
// 1、全选
// 父checkbox,子checkbox
// 1.1 获取父checkbox,注册点击事件
var j_cbAll = document.getElementById('j_cbAll');
j_cbAll.onclick = function () {
// 1.2 获取所有的子checkbox,让所有子checkbox的状态跟父checkbox保持一致
var j_tb = document.getElementById('j_tb');
var inputs = j_tb.getElementsByTagName('input');
//遍历,将所有子checkbox状态改为跟父checkbox状态一致
for (var i = 0; i < inputs.length; i++) {
var input = inputs[i];
if (input.type === 'checkbox') {
//将子checkbox状态跟父checkbox状态保持一致
input.checked = this.checked;
}
}
}

2、 当点击子checkbox,如果所有的子checkbox已经被选中,则选中父checkbox,如果有一个子checkbox没有被选中,则不选中父checkbox

(1)循环,判断是否是复选框,若是,则注册点击事件

(2)点击按钮时,判断所有的子checkbox是否都选中,如果都选中,则父checkbox状态设置为选中,如果有一个子checkbox没选中,则父checkbox设置为不选中

以下代码是在第一步骤基础上写的,包括了第一部分的代码

var j_tb = document.getElementById('j_tb');
var inputs = j_tb.getElementsByTagName('input');
var j_cbAll = document.getElementById('j_cbAll');
// 1、全选
// 父checkbox,子checkbox
// 1.1 获取父checkbox,注册点击事件
var j_cbAll = document.getElementById('j_cbAll');
j_cbAll.onclick = function () {
// 1.2 获取所有的子checkbox,让所有子checkbox的状态跟父checkbox保持一致 //遍历,将所有子checkbox状态改为跟父checkbox状态一致
for (var i = 0; i < inputs.length; i++) {
var input = inputs[i];
if (input.type === 'checkbox') {
//将子checkbox状态跟父checkbox状态保持一致
input.checked = this.checked;
}
}
} //1.3 当有一个子checkbox没有被选中时,父checkbox应当不选中,当所有的子checkbox都选中时,应当选中父checkbox
// 给每一个子checkbox注册事件
for (var i = 0; i < inputs.length; i++) {
var input = inputs[i];
//如果不是复选框,则不绑定事件
if (input.type !== 'checkbox') {
continue;
}
input.onclick = function () {
//假设所有子checkbox都已经选中
var allChecked = true;
console.log(inputs);
//判断所有子checkbox是否选中
for (var j = 0; j < inputs.length; j++) {
var input = inputs[j];
//如果不是复选框,则跳到写一次循环
if (input.type !== 'checkbox') {
continue;
}
if (!input.checked) {
allChecked = false;//如果有没选中的
break;
}
} //同步父checkbox和子checkbox的状态
j_cbAll.checked = allChecked;
}
}

3、反选

当点击反选按钮时,将所有的子的checkbox状态取反,然后同步父的checkbox的状态。 以下代码是在第二步骤基础上写的,包括了第二部分的代码

var j_tb = document.getElementById('j_tb');
var inputs = j_tb.getElementsByTagName('input');
var j_cbAll = document.getElementById('j_cbAll');
// 1、全选
// 父checkbox,子checkbox
// 1.1 获取父checkbox,注册点击事件
var j_cbAll = document.getElementById('j_cbAll');
j_cbAll.onclick = function () {
// 1.2 获取所有的子checkbox,让所有子checkbox的状态跟父checkbox保持一致 //遍历,将所有子checkbox状态改为跟父checkbox状态一致
for (var i = 0; i < inputs.length; i++) {
var input = inputs[i];
if (input.type === 'checkbox') {
//将子checkbox状态跟父checkbox状态保持一致
input.checked = this.checked;
}
}
} //1.3 当有一个子checkbox没有被选中时,父checkbox应当不选中,当所有的子checkbox都选中时,应当选中父checkbox
// 给每一个子checkbox注册事件
for (var i = 0; i < inputs.length; i++) {
var input = inputs[i];
//如果不是复选框,则不绑定事件
if (input.type !== 'checkbox') {
continue;
}
input.onclick = function () {
checkAllCheckBox();
}
} // 2、反选
// 1、给反选按钮注册事件
var btn = document.getElementById('btn');
btn.onclick = function () {
for (var i = 0; i < inputs.length; i++) {
var input = inputs[i];
// 2、判断是否是checkbox
if (input.type !== 'checkbox') {
continue;
}
// 3、给所有的子checkbox反选
input.checked = !input.checked;
} // 问题:当选中或取消所有子checkbox时,父checkbox没改变状态
// 4、判断父的checkbox的状态,根据该状态同步父子checkbox状态
checkAllCheckBox(); } //封装子checkbox和父checkbox的状态同步功能
function checkAllCheckBox() {
//假设所有子checkbox都已经选中
var allChecked = true;
//判断所有子checkbox是否选中
for (var j = 0; j < inputs.length; j++) {
var input = inputs[j];
//如果不是复选框,则不绑定事件
if (input.type !== 'checkbox') {
continue;
}
if (!input.checked) {
allChecked = false;//如果有没选中的
}
}
//同步父checkbox和子checkbox的状态
j_cbAll.checked = allChecked;
}

全选和反选小结:

1、给反选按钮注册事件

2、判断是否是checkbox

3、给所有的子checkbox反选

4、判断父的checkbox的状态,根据该状态同步父子checkbox状态

JavaScript Web API 全选反选案例的更多相关文章

  1. javascript总结41:表格全选反选,经典案例详解

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  2. JavaScript 实现全选 / 反选功能

    JavaScript 实现全选 / 反选功能 版权声明:未经授权,内容严禁转载! 构建主体界面 编写 HTML 代码 和 CSS 代码,设计主题界面 <style> #user { wid ...

  3. JavaScript、全选反选-课堂笔记

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. 用javascript实现全选/反选组件

    以下是本人制作的全选/反选 组件,供广大同行参考.指正: 效果如图: 在实现的过程中,全选和全部取消选中这两个功能较为简单,只需用for循环遍历所有复选框为true或false即可.反选也较为简单,也 ...

  5. 表单javascript checkbox全选 反选 全不选

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...

  6. 用JavaScript实现全选-反选

    实现全选-反选 在日常生活我们会遇到需要全选-反选的地方,其实用JavaScript也能实现. 样式如下所示: 样式代码如下所示: <!DOCTYPE html PUBLIC "-// ...

  7. jQuery全选/反选checkbox

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. Dom操作--全选反选

    我们经常会在网站上遇到一些多选的情况,下面我就来说说使用Dom写全选反选的思路. 全选思路:首先,我们来分析一下知道,当我们点击"全选"复选框的时候,所有的复选框应该都被选中,那我 ...

  9. jQuery之标签操作和返回顶部、登录验证、全选反选、克隆示例

    一.样式操作 1.JQ中的样式类 somenode.addClass();// 添加指定的CSS类名. somenode.removeClass();// 移除指定的CSS类名. somenode.h ...

随机推荐

  1. 捷配制作PCB流程

    https://www.jiepei.com/orderprocess.html 以我的板子为例 查看下自己板子的信息 切换到mm 键盘 Q 压缩PCB文件 付款什么的自己哈 改天我有贴片的订单的时候 ...

  2. [HAOI2015]树上染色 树状背包 dp

    #4033. [HAOI2015]树上染色 Description 有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并 将其他的N-K个点染成白 ...

  3. PHP全栈学习笔记33

    javascript能做什么? 语句与注解,标识符,字面量,变量命名规范 JavaScript中的数据类型,其它类型如何转为数据型,操作符 字符方法,数组方法,函数与对象,函数表达式,变量作用域,对象 ...

  4. 2016级移动应用开发在线测试13-Location、Sensor & Network

    有趣有内涵的文章第一时间送达! 喝酒I创作I分享 生活中总有些东西值得分享 @醉翁猫咪  1. 充分利用智能手机的GPS定位信息,创造了O2O的商业模式,打通了线上与线下的信息流和商流,极大地推动了移 ...

  5. Approximate Search

    题目链接:Gym-101492H 动态规划,应该是比较基础的,可是自己就是不会QAQ.... /* 把使用机会当成“花费” */ # include <iostream> # includ ...

  6. 第12组 Beta版本演示

    前言 组长博客 组名: To Be Done 组员和贡献比例 短学号 姓名 分工 贡献比例 614 王永福* 前后端实现.发任务.催进度 30% 440 孙承恺 UI设计 15% 529 邱畅杰 文本 ...

  7. Compute API 关键概念 详解

    Compute API 是 RESTful HTTP 服务,提供管理虚机的能力. 虚机可能有不同的内存大小,CPU数量,硬盘大小,能够在几分钟之内创建出来.和虚机的交互,可以通过Compute API ...

  8. MariaDB主从复制虚拟机实战

    MariaDB简介: MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQ ...

  9. 【CNN】--- 卷积过程中RGB与灰度的区别

    版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/hacker_Dem_br/article/ ...

  10. AIX 系统参数配置

    AIX 系统参数配置 原创 Linux操作系统 作者:fanhongjie 时间:2008-05-08 22:46:37 540 0 AIX内核属于动态内核,核心参数基本上可以自动调整,因此当系统安装 ...