JavaScript 实现全选 / 反选功能

  版权声明:未经授权,内容严禁转载!  


构建主体界面

编写 HTML 代码 和 CSS 代码,设计主题界面

<style>
#user {
width: 500px;
text-align: center;
} #user, #user th, #user td {
border: 1px solid #000;
border-collapse: collapse;
}
</style> <h1>管理员列表</h1>
<table id="user">
<thead>
<tr>
<th><input type="checkbox">全选</th>
<th>管理员ID</th>
<th>姓名</th>
<th>操作</th>
</tr>
</thead>
<tbody>
<tr>
<td><input type="checkbox"></td>
<td>1</td>
<td>Tom</td>
<td>删除修改</td>
</tr>
<tr>
<td><input type="checkbox"></td>
<td>2</td>
<td>Jayvee</td>
<td>删除修改</td>
</tr>
<tr>
<td><input type="checkbox"></td>
<td>3</td>
<td>Mia</td>
<td>删除修改</td>
</tr>
<tr>
<td><input type="checkbox"></td>
<td>4</td>
<td>Jack</td>
<td>删除修改</td>
</tr>
</tbody>
</table>
<button id="reverse" type="button">反向选择</button>
<button id="del" type="button">删除选定</button>

    

思路引导

  设计完主体界面,接下来就要编写 JavaScript 脚本实现 全选/反选 功能,如果要单独建立一个新的 js 文件记得要在HTML界面进行导入命令,导入要在HTML界面最后。

  因为浏览器加载页面的时候从上而下,如果将 JavaScript 文件放在 body上面,在浏览器加载 JavaScript 时HTML 文件的各个标签还没有加载,JavaScript中使用的标签会找不到,出现错误!

实现全选功能

编写JavaScript脚本代码实现 全选功能

// 1 .获取所有触发事件的元素:全选 四个复选框 反选 删除

// 全选
var chbAll = document.querySelector("#user thead tr th:first-child>input");
// console.log(chbAll);
// 四个复选框
var chbs = document.querySelectorAll("#user tbody tr td:first-child>input");
// console.log(chbs);
// 反选
var reverse = document.querySelector("#reverse");
// console.log(reverse);
// 删除选定
var del = document.querySelector("#del");
// console.log(del); // 实现全选功能
// 绑定事件处理函数
chbAll.onclick = function () {
//判断全选当前是否被选中 // 第一种方法
// if (chbAll.checked) {
// // 如果选中四个复选框全选中
// // 循环四个复选框设置 checked 为选中 true
// for (var i = 0; i < chbs.length; i++) {
// chbs[i].checked = true;
// }
// }else {
// // 如果没选中四个复选框全不选中
// // 循环四个复选框设置 checked 为不选中 false
// for (var i = 0; i < chbs.length; i++) {
// chbs[i].checked = false;
// }
// } // 第二种方法。
// 上面方法太冗余,循环设置四个复选框的选中状态和上面全选框一致即可
// 减少代码,简单!
for (var i = 0; i < chbs.length; i++) {
// chbs[i].checked = chbAll.checked;
// 建议使用 this 关键字,以后万一改掉了 id 名字也不会影响~
chbs[i].checked = this.checked;
} }

  

实现四个小复选框的功能

1. 点击其中一个小复选框要判断这四个小的复选框是否全被选中,如果四个全被选中需要将全选按钮勾上。

2. 如果点击其中一个取消了选中,那么全选按钮就是取消的。

总结:点击之后要判断这小复选框是被选中还是取消,如果是选中,就要判断这四个是不是全选中,如果全选中则全选框被选中,如果不是则选中自己。如果点击之后是取消选中,则全选框一定是取消选中的。

继续编写 JavaScript 脚本代码,实现四个小复选框功能
// 为 tbody 中的每一个 chb 绑定事件处理函数
for (var i = 0; i < chbs.length; i++) {
chbs[i].onclick = function () {
// 判断当前chb是选中韩式取消操作
if (this.checked) {
// 如果选中,判断是否都是选中
// (查找tbody中是否有 未被选中的)
var unchecked = document.querySelector("#user tbody tr td:first-child>input:not(:checked)");
if (unchecked == null) {
// 如果没有,设置全选被选中
chbAll.checked = true;
}
} else {
// 如果是取消,则自己取消并且全选也取消
chbAll.checked = false;
} }
}

  

实现 反向选择 和 删除选定 功能

编辑 JavaScript 脚本代码实现 反向选择 和 删除选定 功能

// 反选
reverse.onclick = function () {
// 循环 实现反选
for (var i = 0; i < chbs.length; i++) {
chbs[i].checked = !chbs[i].checked;
}
// 如果选中,判断是否都是选中
// (查找tbody中是否有 未被选中的)
var unchecked = document.querySelector("#user tbody tr td:first-child>input:not(:checked)");
if (unchecked == null) {
// 如果没有,设置全选被选中
chbAll.checked = true;
} else {
chbAll.checked = false;
}
} // 取消选定
del.onclick = function () {
var checked = document.querySelectorAll("#user tbody tr td:first-child>input:checked");
if (checked !== null) {
for (var i = 0; i < checked.length; i++) {
checked[i].checked = false;
}
}
if (chbAll.checked) chbAll.checked = false;
}

  

完整案例代码

 HTML + CSS

<style>
#user {
width: 500px;
text-align: center;
} #user, #user th, #user td {
border: 1px solid #000;
border-collapse: collapse;
}
</style> <h1>管理员列表</h1>
<table id="user">
<thead>
<tr>
<th><input type="checkbox">全选</th>
<th>管理员ID</th>
<th>姓名</th>
<th>操作</th>
</tr>
</thead>
<tbody>
<tr>
<td><input type="checkbox"></td>
<td>1</td>
<td>Tom</td>
<td>删除修改</td>
</tr>
<tr>
<td><input type="checkbox"></td>
<td>2</td>
<td>Jayvee</td>
<td>删除修改</td>
</tr>
<tr>
<td><input type="checkbox"></td>
<td>3</td>
<td>Mia</td>
<td>删除修改</td>
</tr>
<tr>
<td><input type="checkbox"></td>
<td>4</td>
<td>Jack</td>
<td>删除修改</td>
</tr>
</tbody>
</table>
<button id="reverse" type="button">反向选择</button>
<button id="del" type="button">删除选定</button> <script src="mJS.js"></script>

JavaScript 脚本

// 1 .获取所有触发事件的元素:全选 四个复选框 反选 删除

// 全选
var chbAll = document.querySelector("#user thead tr th:first-child>input");
// console.log(chbAll);
// 四个复选框
var chbs = document.querySelectorAll("#user tbody tr td:first-child>input");
// console.log(chbs);
// 反选
var reverse = document.querySelector("#reverse");
// console.log(reverse);
// 删除选定
var del = document.querySelector("#del");
// console.log(del); // 实现全选功能
// 绑定事件处理函数
chbAll.onclick = function () {
//判断全选当前是否被选中 // 第一种方法
// if (chbAll.checked) {
// // 如果选中四个复选框全选中
// // 循环四个复选框设置 checked 为选中 true
// for (var i = 0; i < chbs.length; i++) {
// chbs[i].checked = true;
// }
// }else {
// // 如果没选中四个复选框全不选中
// // 循环四个复选框设置 checked 为不选中 false
// for (var i = 0; i < chbs.length; i++) {
// chbs[i].checked = false;
// }
// } // 第二种方法。
// 上面方法太冗余,循环设置四个复选框的选中状态和上面全选框一致即可
// 减少代码,简单!
for (var i = 0; i < chbs.length; i++) {
// chbs[i].checked = chbAll.checked;
// 建议使用 this 关键字,以后万一改掉了 id 名字也不会影响~
chbs[i].checked = this.checked;
} } // 为 tbody 中的每一个 chb 绑定事件处理函数
for (var i = 0; i < chbs.length; i++) {
chbs[i].onclick = function () {
// 判断当前chb是选中韩式取消操作
if (this.checked) {
// 如果选中,判断是否都是选中
// (查找tbody中是否有 未被选中的)
var unchecked = document.querySelector("#user tbody tr td:first-child>input:not(:checked)");
if (unchecked == null) {
// 如果没有,设置全选被选中
chbAll.checked = true;
}
} else {
// 如果是取消,则自己取消并且全选也取消
chbAll.checked = false;
} }
} // 反选
reverse.onclick = function () {
// 循环 实现反选
for (var i = 0; i < chbs.length; i++) {
chbs[i].checked = !chbs[i].checked;
}
// 如果选中,判断是否都是选中
// (查找tbody中是否有 未被选中的)
var unchecked = document.querySelector("#user tbody tr td:first-child>input:not(:checked)");
if (unchecked == null) {
// 如果没有,设置全选被选中
chbAll.checked = true;
} else {
chbAll.checked = false;
}
} // 取消选定
del.onclick = function () {
var checked = document.querySelectorAll("#user tbody tr td:first-child>input:checked");
if (checked !== null) {
for (var i = 0; i < checked.length; i++) {
checked[i].checked = false;
}
}
if (chbAll.checked) chbAll.checked = false;
}

结束了,这个案例用在 购物车 还是蛮好的~

JavaScript 实现全选 / 反选功能的更多相关文章

  1. jquery 书写全选反选功能

    书写一个后台管理中用到的全选反选功能.代码如下 <!DOCTYPE html> <html lang="en"> <head> <meta ...

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

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

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

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

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

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

  5. jquery实现全选/反选功能

    <!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content=& ...

  6. 用JavaScript实现全选-反选

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

  7. JS全选反选功能

    总选框:<input type="checkbox" class="all" name="all"> 子选框: <inpu ...

  8. jQuery实现全选反选功能

    废话不说,直接上代码! <html> <head> <meta http-equiv="Content-Type" content="tex ...

  9. JQuery实现列表中复选框全选反选功能封装

    我们在做列表的时候经常会遇到全选,反选进行批量处理问题,例如: 我当时就是简单的实现了,然后想封装到公共的js中,封装的太烂,不好意思贴出来了(就是把实现代码之间放到公共js中,然后每个页面都用固定的 ...

随机推荐

  1. opengl学习笔记(三):经过纹理贴图的棋盘

    opengl纹理贴图的步骤: 1:创建纹理对象,并为它指定一个纹理 2:确定纹理如何应用到每个像素上 3:启用纹理贴图功能 4:绘制场景,提供纹理坐标和几何图形坐标 注意:纹理坐标必须在RGBA模式下 ...

  2. PAT-GPLT L2-027 - 名人堂与代金券 - [简单模拟]

    题目链接:https://www.patest.cn/contests/gplt/L2-027 对于在中国大学MOOC(http://www.icourse163.org/)学习“数据结构”课程的学生 ...

  3. POJ - 1101 The Game dfs

    题意:给你一个地图,上面有一些‘X',给你起点终点,让你输出从起点到终点的路径中转向(改变方向)次数最少的路径,注意,不能穿过别的’X'并且可以超过边界 题解:关于超过边界,只要在外围多加一圈‘ ’. ...

  4. CCCC 排座位 图着色问题

    1排座位:https://www.patest.cn/contests/gplt/L2-010 2图着色问题 https://www.patest.cn/contests/gplt/L2-023 建图 ...

  5. create view in view

    CREATE VIEW view_region2role AS ( SELECT region_set_id, region_set_name, GROUP_CONCAT(id) gc_id, GRO ...

  6. Cross-origin resource sharing JSON with Padding 同源策略 JSONP 为什么form表单提交没有跨域问题,但ajax提交有跨域问题? XMLHttpRequest and the Fetch API follow the same-origin policy 预检请求(preflight request)

    https://zh.wikipedia.org/wiki/跨来源资源共享 跨来源资源共享(CORS)是一份浏览器技术的规范,提供了 Web 服务从不同域传来沙盒脚本的方法,以避开浏览器的同源策略[1 ...

  7. Balls and Boxes---hdu5810(推公式)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5810 有n个球m个盒子,随机把球放到盒子中,求每个盒子球个数的方差的期望值 E[V]; 推公式吧,或者 ...

  8. Python开发【笔记】:what?进程queue还能生产出线程!

    进程queue底层用线程传输数据 import threading import multiprocessing def main(): queue = multiprocessing.Queue() ...

  9. 字符编码笔记:ASCII,Unicode和UTF-8(转载)

    注:我注释的地方有 add by zhj.另Unicode.UTF-8.GB2312查询http://www.2fz1.com/so/ 在python中,a.decode(xxx)就是把str类型的字 ...

  10. SQL Server 安装后改动计算机名带来的问题以及解决方法

    USE master GO DECLARE @serverproperty_servername varchar(100), @servername varchar(100) --取得Windows ...