JS实现全选

 
嗨,同学们好,老师这里是专门教同学解决一些针对性的问题,所以说综合起来,就要靠同学自己了。
这节课我们学一个很实用的东西,全选操作!比如淘宝这种商城对吧,我的购物车,我要全选购买,或者删除,一个一个的来肯定麻烦,所以就有了全选和批量处理,那就是复选框!
 
这里我们用一个table表格来控制吧!看代码:
 
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>JS全选,复选框</title>
</head>
<body>
<table id="mytable">
<tr>
<th><input type="checkbox" id="quan"/></th>
<th>序号</th>
<th>姓名</th>
<th>性别</th>
<th>地址</th>
</tr>
<tr>
<td><input type="checkbox"/></td>
<td>1</td>
<td>张三</td>
<td>女</td>
<td>四川省成都市</td>
</tr>
<tr>
<td><input type="checkbox"/></td>
<td>2</td>
<td>李斯</td>
<td>女</td>
<td>四川省成都市</td>
</tr>
<tr>
<td><input type="checkbox"/></td>
<td>3</td>
<td>玩玩玩</td>
<td>男</td>
<td>四川省成都市</td>
</tr>
<tr>
<td><input type="checkbox"/></td>
<td>4</td>
<td>哈哈哈</td>
<td>女</td>
<td>四川省成都市</td>
</tr>
</table>
<script>
// onload事件 页面加载完直接运行
window.onload = function () {
var mytable = document.getElementById("mytable");
var qq = document.getElementById("quan");
mytable.style.border = "1px solid gray";
mytable.style.borderCollapse = "collapse";
mytable.style.textAlign = "center";
mytable.style.width = "800px";
//以上是给table表格添加样式
//使用循环获取到表格的tr长度
for (i = 1; i < mytable.rows.length; i++) {
//因为复选框是tr里的第一个,所以cells里的数组下标为0
mytable.rows[i].cells[0].firstChild.onclick = function () {
//当我点击它,就做判断
//先判断它本身是被选中的就往下面走
if (this.checked) {
//如果它被选中我们就走进for循环
for (j = 1; j < mytable.rows.length; j++) {
//获取tr的长度,然后判断所有的复选框
if (!mytable.rows[j].cells[0].firstChild.checked) {
//如果这些复选框,有一个没有被选中,全选就变成未被选中
qq.checked = false;
return true;
//最后结束返回 true
}
}
//if判断,所有复选框都是选中的,就让全选变成true 变成选中
qq.checked=true;
}
else {
//如果它本身没有被选中,全选当然是变成false 未被选中
qq.checked = false;
}
}
}
//点击全选的复选框,将所有的复选框变成和它一样,要么选中,要么未选中
qq.onclick=function() {
for (i = 1; i < mytable.rows.length; i++) {
mytable.rows[i].cells[0].firstChild.checked = this.checked;
}
};
//以下是循环并判断表格里的tr和td,添加css样式
for (i = 0; i < mytable.rows.length; i++) {
if (i == 0) {
mytable.rows[0].style.backgroundColor = "lightgray";
} else {
mytable.rows[i].onmouseover = function () {
this.style.backgroundColor = "red";
};
mytable.rows[i].style.cursor = "pointer";
if (i % 2 == 0) {
mytable.rows[i].style.backgroundColor = "yellow";
mytable.rows[i].onmouseout = function () {
this.style.backgroundColor = "yellow";
}
} else {
mytable.rows[i].style.backgroundColor = "orange";
mytable.rows[i].onmouseout = function () {
this.style.backgroundColor = "orange";
}
}
}
for (j = 0; j < mytable.rows[i].cells.length; j++) {
var c = mytable.rows[i].cells[j];
c.style.border = "1px solid gray";
}
}
}
</script>
</body>
</html>
 
以上代码,同学们主要看的不是给table表格添加样式,当然了,最下面的代码,判断和循环那里可以多看看,是什么意思,我没写注释,重点是,全选的操作那里。
代码同学们可以直接copy拿走,但是一定要了解里面的代码,这样你修改成自己的代码也就简单了,而且以后自己才能写出来哦。
 

第十六篇 JS实现全选操作的更多相关文章

  1. 利用js写全选操作

    <script type="text/javascript"> function checkall(qx) { var ck=document.getElementsB ...

  2. Python之路【第十六篇】:Django【基础篇】

    Python之路[第十六篇]:Django[基础篇]   Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...

  3. 跟我学SpringCloud | 第十六篇:微服务利剑之APM平台(二)Pinpoint

    目录 SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint 1. Pinpoint概述 2. Pinpoint主要特性 3. Pinpoint优势 4. Pinp ...

  4. Egret入门学习日记 --- 第十六篇(书中 6.10~7.3节 内容)

    第十六篇(书中 6.10~7.3节 内容) 昨天搞定了6.9节,今天就从6.10节开始. 其实这个蛮简单的. 这是程序员模式. 这是设计师模式. 至此,6.10节 完毕. 开始 6.11节. 有点没营 ...

  5. 解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译)

    解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译) http://improve.dk/orcamdf-rawdatabase-a-swiss-a ...

  6. JS checkbox 全选 全不选

    /* JS checkbox 全选 全不选 Html中checkbox: <input type="checkbox" name="cbx" value= ...

  7. JS实现全选、反选、不选

    JS实现全选.反选.不选 效果图: 代码如下,复制即可使用: <!DOCTYPE html> <html> <head> <meta charset=&quo ...

  8. elementUI+JS实现全选与反选

    在实际项目开发过程中,遇到的需求,需要实现全选以及取消全选等功能,主要使用ElementUI + JS来实现,具体代码如下: <!DOCTYPE html> <html lang=& ...

  9. JS实战 · 复选框全选操作

    思路: 1.获取被选中checkbox,通过checked属性的状态完成: 2.获取被选中的checkbox的value值: 3.求所有value的和sum: 4.定义span区域存储和sum:   ...

随机推荐

  1. venv转向pipenv

    先编译安装你需要的Python版本:参考https://www.cnblogs.com/zxpo/p/10011871.html python3.6安装在:/usr/bin/python3.6目录下: ...

  2. Android版本之间的区别

    不同版本SDK适配要点 1,指定minSDKVersion与targetSDKVersion 2,运行时获取版本号 3,使用系统内置的主题,会随着版本的更换而自动适配 4,用android提供的注解 ...

  3. 解决json_encode中文乱码问题

    关键字JSON_UNESCAPED_UNICODE即Json不要编码Unicode. $arr={"name":"你好"}; json_encode($arr, ...

  4. Web jsp开发学习——终极解决jsp中request和response中文乱码的问题(加个过滤器)

    中文乱码真的很烦人的.而且每次都要写,可麻烦了,而且有时候写了还不一定管用,所以我们可以试试过滤器 1.每个jsp头上当然要写上utf8啦 <%@ page language="jav ...

  5. shell脚本安装python、pip-----非交互式的--批量执行函数

    首先把pip-.tgz 安装包放在 /usr/local 下面,按照顺序先安装pip,再安装python.不要先安装或只安装python,否则很容易出错, cat >>pip-python ...

  6. java:solr

    1.solr(数据导入solr自带数据库):   ImportItemController.java: package com.solr.controller; import org.springfr ...

  7. Htmlunit 设置缓存文件

    起因:最近用Htmlunit爬取网页.demo运行起来后,发现速度相当慢,一直在不停的加载js文件,偶尔还会报错,js超时等.抓包工具看了一下请求,发现一直在不停的下载js文件.按理说请求过js文件后 ...

  8. 【计算机视觉】论文笔记:Ten years of pedestrian detection, what have we learned?

    最近正在研究行人检测,学习了一篇2014年发表在ECCV上的一篇综述性的文章,是对行人检测过去十年的一个回顾,从dataset,main approaches的角度分析了近10年的40多篇论文提出的方 ...

  9. C++四种类型转换总结

    C风格的强制类型转换很简单,均用 Type b = (Type)a 形式转换.C++风格的类型转换提供了4种类型转换操作符来应对不同场合的应用,如下表: 转换类型操作符 作用 const_cast 去 ...

  10. 2019牛客暑期多校训练营(第二场)-D Kth Minimum Clique

    题目链接:https://ac.nowcoder.com/acm/contest/882/D 题意:求给定点权无向图中,点权和第k小的完全子图的点权和.(包括空集) 思路:从空集开始,每找到一个完全子 ...