第十六篇 JS实现全选操作
JS实现全选
<!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>
第十六篇 JS实现全选操作的更多相关文章
- 利用js写全选操作
<script type="text/javascript"> function checkall(qx) { var ck=document.getElementsB ...
- Python之路【第十六篇】:Django【基础篇】
Python之路[第十六篇]:Django[基础篇] Python的WEB框架有Django.Tornado.Flask 等多种,Django相较与其他WEB框架其优势为:大而全,框架本身集成了O ...
- 跟我学SpringCloud | 第十六篇:微服务利剑之APM平台(二)Pinpoint
目录 SpringCloud系列教程 | 第十六篇:微服务利剑之APM平台(二)Pinpoint 1. Pinpoint概述 2. Pinpoint主要特性 3. Pinpoint优势 4. Pinp ...
- Egret入门学习日记 --- 第十六篇(书中 6.10~7.3节 内容)
第十六篇(书中 6.10~7.3节 内容) 昨天搞定了6.9节,今天就从6.10节开始. 其实这个蛮简单的. 这是程序员模式. 这是设计师模式. 至此,6.10节 完毕. 开始 6.11节. 有点没营 ...
- 解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译)
解剖SQLSERVER 第十六篇 OrcaMDF RawDatabase --MDF文件的瑞士军刀(译) http://improve.dk/orcamdf-rawdatabase-a-swiss-a ...
- JS checkbox 全选 全不选
/* JS checkbox 全选 全不选 Html中checkbox: <input type="checkbox" name="cbx" value= ...
- JS实现全选、反选、不选
JS实现全选.反选.不选 效果图: 代码如下,复制即可使用: <!DOCTYPE html> <html> <head> <meta charset=&quo ...
- elementUI+JS实现全选与反选
在实际项目开发过程中,遇到的需求,需要实现全选以及取消全选等功能,主要使用ElementUI + JS来实现,具体代码如下: <!DOCTYPE html> <html lang=& ...
- JS实战 · 复选框全选操作
思路: 1.获取被选中checkbox,通过checked属性的状态完成: 2.获取被选中的checkbox的value值: 3.求所有value的和sum: 4.定义span区域存储和sum: ...
随机推荐
- 取得远端相应Json并转化为Java对象一
JDK:1.8.0_212 IDE:STS4(Spring Tool Suit4 Version: 4.3.2.RELEASE) 工程下载:https://files.cnblogs.com/file ...
- Android jni/ndk编程一:jni初级认识与实战体验
Android平台很多地方都可以看到jni的身影,比如之前接触到一个投屏的项目,主要的代码是c/c++写的,然后通过Jni供Java层调用;另外,就拿Android系统中的Service来说,很多的S ...
- 手动部署 OpenStack Rocky 双节点
目录 文章目录 目录 前言 OpenStack 架构 Conceptual architecture Logical architecture 网络选型 Networking Option 1: Pr ...
- (4)rapidxml的详解及使用
RapidXml是指 XML DOM解析工具包,是一个快速的读写xml文件的库文件(hpp). (1)创建XML文件 #include <iostream> #includ ...
- Swift3.0基础语法学习<一>
// // ViewController.swift // SwiftBasicDemo // // Created by 思 彭 on 16/11/15. // Copyright © 2016年 ...
- EF Code First 学习笔记:约定配置 Data Annotations+Fluent API
要更改EF中的默认配置有两个方法,一个是用Data Annotations(在命名空间System.ComponentModel.DataAnnotations;),直接作用于类的属性上面;还有一个就 ...
- java:JQuery(Ajax,JSON)
1.遍历ajax返回的json: 第一种: <%@ page language="java" import="java.util.*" pageEncod ...
- appium+python+windows环境配置
一.安装node.js 1:先找到对于电脑合适的node版本进行下载. 我的云盘node版本是7.8.0.地址如下:https://pan.baidu.com/s/19kcpXhCN1AuJAT9CB ...
- PHP架构剖析
一:PHP是什么 PHP("PHP: Hypertext Preprocessor",超文本预处理器的字母缩写)是一种被广泛应用的开放源代码的多用途脚本语言,它可嵌入到 HTML中 ...
- git 提交项目到远程仓库,简单实现忽略 node_modules文件
在项目根目录中创建 .gitignore文件 在文件中添加你要忽略的文件 .DS_Store node_modules /dist # local env files .env.local .env. ...