WEB前端08-综合案例(动态表格)

使用 HTML、CSS 和 JavaScript 创建动态表格

在本教程中,我们将创建一个动态表格,允许用户添加行、选择项目,并执行批量操作,如全选或删除选中的行。我们将通过 HTML、CSS 和 JavaScript 来实现这一功能。让我们逐步了解每个部分是如何协同工作的。

image-20240720185405657

HTML 结构

我们的 HTML 文档设置了页面的基本结构:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>动态表格</title><style>/* CSS 样式在这里 */</style>
</head>
<body><div class="container"><!-- 输入字段和添加按钮 --><div class="div_1"><input type="text" name="id" id="id" placeholder="请输入编号"><input type="text" name="name" id="name" placeholder="请输入用户名"><input type="text" name="sex" id="sex" placeholder="请输入性别"><input type="button" value="添加" id="bn_add"></div><!-- 表格显示学生信息 --><div class="div_2"><table><caption>学生信息表</caption><!-- 表头 --><tr onmouseover="doOver(this);" onmouseout="doOut(this);"><th><input type="checkbox" id="doChoose"></th><th>编号</th><th>姓名</th><th>性别</th><th>操作</th></tr><!-- 示例数据行 --><tr onmouseover="doOver(this);" onmouseout="doOut(this);"><td><input type="checkbox" name="user"></td><td>1</td><td>张三</td><td></td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr></table></div><!-- 操作按钮 --><div class="div_3"><input type="button" value="全选" id="chooseAll"><input type="button" value="全不选" id="chooseNull"><input type="button" value="反选" id="chooseFan"><input type="button" value="删除" id="deleteTable"></div></div><script>/* JavaScript 函数在这里 */</script>
</body>
</html>

HTML 元素说明

  1. 容器 Div:
    • .container 类将所有元素包裹在一起,为其添加了内边距和阴影效果,使页面看起来更像卡片。
  2. 输入字段和按钮:
    • .div_1 类包含 ID、姓名和性别的输入字段以及一个添加新行的按钮。
  3. 表格:
    • 表格显示学生信息,包含选择框、编号、姓名、性别和操作列。每一行都有一个删除选项。
  4. 操作按钮:
    • .div_3 类包含全选、全不选、反选和删除选中行的按钮。

CSS 样式

CSS 用于美化表格和输入字段。以下是 CSS 的简要说明:

body {font-family: Arial, sans-serif; /* 设置全局字体 */background-color: #f2f2f2; /* 设置背景颜色 */color: #333; /* 设置文本颜色 */margin: 0; /* 去除默认外边距 */padding: 20px; /* 设置页面内边距 */
}.container {width: 80%; /* 设置容器宽度 */margin: auto; /* 居中容器 */background: #fff; /* 背景颜色为白色 */padding: 20px; /* 添加内边距 */box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); /* 添加阴影效果 */
}.div_1 {text-align: center; /* 居中对齐内容 */margin-bottom: 20px; /* 添加下边距 */
}.div_1 input[type="text"] {padding: 10px; /* 添加内边距 */margin-right: 10px; /* 添加右边距 */border: 1px solid #ccc; /* 设置边框 */border-radius: 5px; /* 设置圆角边框 */
}.div_1 input[type="button"] {padding: 10px 20px; /* 添加内边距 */background-color: #007BFF; /* 背景颜色 */color: white; /* 文本颜色 */border: none; /* 去除边框 */border-radius: 5px; /* 设置圆角边框 */cursor: pointer; /* 设置鼠标样式 */
}.div_1 input[type="button"]:hover {background-color: #0056b3; /* 悬停时背景颜色变化 */
}table {width: 100%; /* 设置表格宽度 */border-collapse: collapse; /* 合并边框 */margin-bottom: 20px; /* 添加下边距 */
}table,
td,
th {border: 1px solid #ddd; /* 设置边框 */
}th,
td {padding: 12px; /* 添加内边距 */text-align: center; /* 居中对齐文本 */
}th {background-color: #007BFF; /* 表头背景颜色 */color: white; /* 表头文本颜色 */
}caption {font-size: 1.5em; /* 设置标题字体大小 */margin: 10px; /* 添加边距 */color: #007BFF; /* 设置标题颜色 */
}.div_3 {text-align: center; /* 居中对齐内容 */font-family: Arial, sans-serif; /* 设置字体 */color: #333; /* 设置文本颜色 */
}.div_3 input[type="button"] {padding: 10px 20px; /* 添加内边距 */margin: 5px; /* 添加边距 */background-color: #28a745; /* 背景颜色 */color: white; /* 文本颜色 */border: none; /* 去除边框 */border-radius: 5px; /* 设置圆角边框 */cursor: pointer; /* 设置鼠标样式 */
}.div_3 input[type="button"]:hover {background-color: #218838; /* 悬停时背景颜色变化 */
}tr:hover {background-color: #f1f1f1; /* 行悬停时背景颜色变化 */
}a {color: #007BFF; /* 链接颜色 */text-decoration: none; /* 去除下划线 */
}a:hover {text-decoration: underline; /* 悬停时添加下划线 */
}

关键 CSS 特性

  1. 容器样式:
    • .container 类将内容居中,并添加了内边距和阴影效果,使页面更具吸引力。
  2. 按钮样式:
    • 按钮具有内边距、背景色和悬停效果,提高了可用性。
  3. 表格样式:
    • 表格有清晰的边框、内边距,并且行在悬停时有背景色变化效果,提升了用户体验。
  4. 链接样式:
    • 链接样式与整体主题一致,并在悬停时显示下划线。

JavaScript 功能

JavaScript 代码处理表格的动态功能:

// 获取添加按钮元素
let add = document.getElementById("bn_add");// 点击添加按钮时触发的事件处理函数
add.onclick = function () {// 获取输入字段的值let id_text = document.getElementById("id").value;let name_text = document.getElementById("name").value;let sex_text = document.getElementById("sex").value;// 获取表格元素let table = document.getElementsByTagName("table")[0];// 插入新行let newRow = table.insertRow();newRow.innerHTML ="<td><input type='checkbox' name='user'></td>" +"<td>" + id_text + "</td>" +"<td>" + name_text + "</td>" +"<td>" + sex_text + "</td>" +"<td><a href='javascript:void(0);' οnclick='delTr(this);'>删除</a></td>";// 添加鼠标悬停效果newRow.onmouseover = function () {doOver(newRow);};newRow.onmouseout = function () {doOut(newRow);};
}// 主选择框的点击事件处理函数
document.getElementById("doChoose").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = this.checked; // 根据主选择框的状态设置复选框的状态}
};// 删除指定行的函数
function delTr(obj) {let table = obj.parentNode.parentNode.parentNode; // 获取表格let tr = obj.parentNode.parentNode; // 获取当前行table.removeChild(tr); // 删除当前行
}// 全选操作
document.getElementById("chooseAll").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = true; // 全部勾选}
}// 全不选操作
document.getElementById("chooseNull").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = false; // 全部取消勾选}
}// 反选操作
document.getElementById("chooseFan").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = !userArray[index].checked; // 反转每个复选框的状态}
}// 删除选中行操作
document.getElementById("deleteTable").onclick = function () {let userArray = document.getElementsByName("user");for (let index = userArray.length - 1; index >= 0; index--) {if (userArray[index].checked) {delTr(userArray[index]); // 删除选中的行}}
}// 行悬停效果函数
function doOver(row) {row.style.backgroundColor = "pink"; // 悬停时背景色变为粉色
}// 行悬停离开效果函数
function doOut(row) {row.style.backgroundColor = "white"; // 离开时背景色恢复为白色
}

JavaScript 功能说明

  1. 添加行:

    • add.onclick 处理输入字段的值,并在表格中添加新行,同时设置了悬停效果。
    在插入行时使用let newRow = table.insertRow();可以有效的插入表格,使得表格为一体
    或者使用childNode等属性插入
    直接table.innerHTML += 表格代码不会将其拼接为一个整体表格。调整了使用 innerHTML 方法添加新行的方式,确保将新行正确插入表格中,而不是简单地将其附加到表格的 innerHTML。
    
  2. 全选/全不选操作:

    • doChoose 处理全选和全不选操作,根据主选择框的状态更新复选框。
  3. 删除操作:

    • delTr 函数通过获取父元素删除特定行。
  4. 批量操作按钮:

    • chooseAllchooseNullchooseFan 分别实现全选、全不选和反选复选框。
    //批量删除
    document.getElementById("deleteTable").onclick = function () {let userArray = document.getElementsByName("user");for (let index = userArray.length - 1; index >= 0; index--) {if (userArray[index].checked) {delTr(userArray[index]); // 删除选中的行}}
    }
    如果我们正序删除时,userArray.length会不断变化这样会使我们每次只能删除一般,这时我们可以采取倒序删除的方法,原理如下:倒着删除不会出现上述错误的原因是,当你从后往前删除时,每次删除一行后,不会影响到尚未遍历到的元素索引。具体来说:当你正向删除时,如果删除的是索引较小的元素,后面的元素会向前移动一个位置,导致索引发生变化,从而跳过某些元素。
    倒着删除时,每次删除操作都影响已经遍历过的元素,不会影响到尚未遍历到的元素的索引,因此不会跳过任何元素。
    让我们详细看一下这两种删除方式的工作原理。正向删除
    假设你有一个数组 userArray,其长度为 5,其中元素分别为 A, B, C, D, E,并且你需要删除 BD。初始状态:[A, B, C, D, E]
    第一次删除 B 后:[A, C, D, E]
    CD 分别移动到原来 BC 的位置。
    第二次遍历到原来的索引 3 位置:E,跳过了 D。
    倒着删除
    初始状态:[A, B, C, D, E]
    第一次删除 D 后:[A, B, C, E]
    E 移动到原来 D 的位置。
    第二次删除 B 后:[A, C, E]
    此时,CE 的位置没有影响。
    从后往前删除时,每次删除操作都不会影响到未遍历到的元素的索引,因此不会出现跳过的问题。
    
  5. 行悬停效果:

    • doOverdoOut 函数在行悬停时更改背景颜色,提高用户体验。

image-20240720185454032

完整源码:

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>动态表格</title><style>body {font-family: Arial, sans-serif;background-color: #f2f2f2;color: #333;margin: 0;padding: 20px;}.container {width: 80%;margin: auto;background: #fff;padding: 20px;box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);}.div_1 {text-align: center;margin-bottom: 20px;}.div_1 input[type="text"] {padding: 10px;margin-right: 10px;border: 1px solid #ccc;border-radius: 5px;}.div_1 input[type="button"] {padding: 10px 20px;background-color: #007BFF;color: white;border: none;border-radius: 5px;cursor: pointer;}.div_1 input[type="button"]:hover {background-color: #0056b3;}table {width: 100%;border-collapse: collapse;margin-bottom: 20px;}table,td,th {border: 1px solid #ddd;}th,td {padding: 12px;text-align: center;}th {background-color: #007BFF;color: white;}caption {font-size: 1.5em;margin: 10px;color: #007BFF;}.div_3 {text-align: center;font-family: Arial, sans-serif;color: #333;}.div_3 input[type="button"] {padding: 10px 20px;margin: 5px;background-color: #28a745;color: white;border: none;border-radius: 5px;cursor: pointer;}.div_3 input[type="button"]:hover {background-color: #218838;}tr:hover {background-color: #f1f1f1;}a {color: #007BFF;text-decoration: none;}a:hover {text-decoration: underline;}</style>
</head><body><div class="container"><div class="div_1"><input type="text" name="id" id="id" placeholder="请输入编号"><input type="text" name="name" id="name" placeholder="请输入用户名"><input type="text" name="sex" id="sex" placeholder="请输入性别"><input type="button" value="添加" id="bn_add"></div><div class="div_2"><table><caption>学生信息表</caption><tr onmouseover="doOver(this);" onmouseout="doOut(this);"><th><input type="checkbox" id="doChoose"></th><th>编号</th><th>姓名</th><th>性别</th><th>操作</th></tr><tr onmouseover="doOver(this);" onmouseout="doOut(this);"><td><input type="checkbox" name="user"></td><td>1</td><td>张三</td><td></td><td><a href="javascript:void(0);" onclick="delTr(this);">删除</a></td></tr></table></div><div class="div_3"><input type="button" value="全选" id="chooseAll"><input type="button" value="全不选" id="chooseNull"><input type="button" value="反选" id="chooseFan"><input type="button" value="删除" id="deleteTable"></div></div><script>let add = document.getElementById("bn_add");add.onclick = function () {let id_text = document.getElementById("id").value;let name_text = document.getElementById("name").value;let sex_text = document.getElementById("sex").value;let table = document.getElementsByTagName("table")[0];let newRow = table.insertRow();newRow.innerHTML ="<td><input type='checkbox' name='user'></td>" +"<td>" + id_text + "</td>" +"<td>" + name_text + "</td>" +"<td>" + sex_text + "</td>" +"<td><a href='javascript:void(0);' οnclick='delTr(this);'>删除</a></td>";newRow.onmouseover = function () {doOver(newRow);};newRow.onmouseout = function () {doOut(newRow);};}document.getElementById("doChoose").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = this.checked;}};function delTr(obj) {let table = obj.parentNode.parentNode.parentNode;let tr = obj.parentNode.parentNode;table.removeChild(tr);}document.getElementById("chooseAll").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = true;}}document.getElementById("chooseNull").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = false;}}document.getElementById("chooseFan").onclick = function () {let userArray = document.getElementsByName("user");for (let index = 0; index < userArray.length; index++) {userArray[index].checked = !userArray[index].checked;}}document.getElementById("deleteTable").onclick = function () {let userArray = document.getElementsByName("user");for (let index = userArray.length - 1; index >= 0; index--) {if (userArray[index].checked) {delTr(userArray[index]);}}}//悬停在每一行上面变化颜色function doOver(row) {row.style.backgroundColor = "pink";}function doOut(row) {row.style.backgroundColor = "white";}</script>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/47454.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

kubernetes集群部署elasticsearch集群,包含无认证和有认证模式

1、背景&#xff1a; 因公司业务需要&#xff0c;需要在测试、生产kubernetes集群中部署elasticsearch集群&#xff0c;因不同环境要求&#xff0c;需要部署不同模式的elasticsearch集群&#xff0c; 1、测试环境因安全性要求不高&#xff0c;是部署一套默认配置&#xff1b; 2…

【程序设计-底层设计-串口通信-底层交互-一些定义-嵌入式学习-自己思考(1)】

【程序设计-底层设计-串口通信-底层交互-一些定义-嵌入式学习-自己思考&#xff08;1&#xff09;】 1、概述2、环境说明3、学习部分-底层硬件1、当我们说&#xff1a;底层串口-TX&RT&#xff0c;我们在说什么&#xff08;1&#xff09;uart&#xff08;Universal Asynchro…

数学建模~~~SPSS相关和回归分析

目录 1.双变量相关分析 1.1理论基础 1.2简单散点图的绘制介绍 1.3相关性分析 1.4分析相关性结果 2.简单线性回归分析 2.1简单概括 2.2分析过程 2.3结果分析 3.曲线回归分析 3.1问题介绍 3.2分析过程 3.3结果分析 1.双变量相关分析 1.1理论基础 双变量相关分析并不…

HTML5-canvas1

1、canvas&#xff1a;创建画布 <canvas id"canvas"></canvas>2、画一条直线 var canvasdocument.getElementById(cancas&#xff09;; canvas.width800; canvas.height800; var contextcanvas.getContext(2d); //获得2d绘图上下文环境 //画一条直线 c…

码蹄集部分题目(2024OJ赛7.17-7.21;并查集+最小生成树+线段树+树状数组+DP)

1&#x1f40b;&#x1f40b;供水管线&#xff08;钻石&#xff1b;并查集最小生成树&#xff09; 时间限制&#xff1a;1秒 占用内存&#xff1a;128M &#x1f41f;题目思路 该题目就是最小生成树的问题。我们使用选边的方法&#xff0c;每次选取最小边加入&#xff0c;用…

Kettle 登录示例 POST请求

登录接口是post请求&#xff0c;组装Body为json字符串 var body "{\"username\":\""username"\",\"password\": \""password"\",\"code\":\""verification"\",\"uuid\…

小阿轩yx-高性能内存对象缓存

小阿轩yx-高性能内存对象缓存 案例分析 案例概述 Memcached 是一款开源的高性能分布式内存对象缓存系统用于很多网站提高访问速度&#xff0c;尤其是需要频繁访问数据的大型网站是典型的 C/S 架构&#xff0c;需要构建 Memcached 服务器端与 Memcached API 客户端用 C 语言…

【C++】内存管理的深度解析与实例

C内存管理的深度解析与实例 一、C内存管理的基本概念二、C内存分配方式1. 静态内存分配2. 动态内存分配 三、C内存管理的常见问题及解决策略1. 内存泄漏2. 堆内存碎片化3. 栈溢出 四、C内存管理的最佳实践1. 使用RAII&#xff08;Resource Acquisition Is Initialization&#…

【BUG】已解决:python setup.py bdist_wheel did not run successfully.

已解决&#xff1a;python setup.py bdist_wheel did not run successfully. 目录 已解决&#xff1a;python setup.py bdist_wheel did not run successfully. 【常见模块错误】 解决办法&#xff1a; 欢迎来到英杰社区https://bbs.csdn.net/topics/617804998 欢迎来到我的主…

在Django项目中创建Django App

进入code虚拟环境 .\.venv\Scripts\activate创建demoapp python demo/manage.py startapp demoapp

Neuralink首款产品Telepathy:意念控制设备的革新与挑战

近年来&#xff0c;科技领域不断涌现出令人惊叹的突破&#xff0c;其中尤以脑机接口&#xff08;BCI&#xff09;技术为代表。近日&#xff0c;Elon Musk的Neuralink公司发布了其首款脑机接口产品Telepathy&#xff0c;引发了广泛关注。本文将详细探讨Telepathy的功能、技术原理…

PCIe总线-RK3588 PCIe平台驱动分析(十)

1.简介 RK3588 PCIe RC和EP使用同一个平台驱动&#xff0c;其主要的作用是解析设备树中的资源、初始化中断、使能电源、初始化PHY、使能时钟和释放复位&#xff0c;然后根据compatible属性初始化RC或者EP驱动。 2.入口 平台驱动的定义如下&#xff0c;当compatible属性为&qu…

C语言:静态库和动态(共享)库

相关阅读 C语言https://blog.csdn.net/weixin_45791458/category_12423166.html?spm1001.2014.3001.5482 在软件开发中&#xff0c;库&#xff08;Library&#xff09;是一个至关重要的概念。它们是由函数和数据的集合构成&#xff0c;用于实现特定的功能&#xff0c;供其他程…

使用Vuepress搭建个人网站

网站地址&#xff1a;bloggo.chat

MySQL学习作业二

作业描述 SQL语言 建库&#xff0c;使用库 mysql> create database mydb8_worker;#新建库mysql> use mydb8_worker; 建表&#xff0c;查看表 #建表 mysql> create table t_worker(department_id int(11) not null comment部门号,worker_id int(11) primary key no…

无人机足球比赛技术详解

一、无人机类型参数 在无人机比赛中&#xff0c;不同类型的无人机因其独特的参数配置而表现出不同的性能。这些参数包括但不限于&#xff1a; 1. 机体尺寸&#xff1a;小型无人机适合室内或狭窄空间比赛&#xff0c;而大型无人机则更适用于室外大场地赛事。 2. 动力系统&…

动态路由协议 —— EIGRP 与 OSPF 的区别

EIGRP&#xff08;增强内部网关路由协议&#xff09;和 OSPF&#xff08;开放式最短路径优先&#xff09;是两种最常见的动态路由协议&#xff0c;主要是用来指定路由器或交换机之间如何通信。将其应用于不同的情况下&#xff0c;可提高速率、延迟等方面的性能。那么它们之间到…

IO多路复用-select的使用详解【C语言】

1.多进程/线程并发和IO多路复用的对比 IO多路转接也称为IO多路复用&#xff0c;它是一种网络通信的手段&#xff08;机制&#xff09;&#xff0c;通过这种方式可以同时监测多个文件描述符并且这个过程是阻塞的&#xff0c;一旦检测到有文件描述符就绪&#xff08; 可以读数据…

【数据结构进阶】二叉搜索树

&#x1f525;个人主页&#xff1a; Forcible Bug Maker &#x1f525;专栏&#xff1a; C || 数据结构 目录 &#x1f308;前言&#x1f525;二叉搜索树&#x1f525; 二叉搜索树的实现Insert&#xff08;插入&#xff09;find&#xff08;查找&#xff09;erase(删除)destro…

分布式锁、Lua脚本、redisson、运行lua脚本优化代码

20240721 一、分布式锁1. 什么是分布式锁2. 分布式锁的实现3. 基于redis的分布式锁4 总结 二、对于lua脚本可以保证事务&#xff0c;要么成功要么失败。1. 在redis中调用lua脚本 三、Redisson1 步骤2. Redisson的总结3. 几种分布式锁的区别 三、优化我们的秒杀1. 我们在创建优惠…