105-----JS基础-----添加删除记录-修改

2023-10-31

一 代码

本节的代码是对104节的内容进行优化,因为按照上一节的内容这样写的话,会创建过多的资源,造成资源浪费,导致用户体验不好,当界面复杂起来,可能会变得很卡,造成用户体验不好,所以需要进行优化。

下面的例子,避免了人为的创建多个节点元素,使用createElement + innerHTML的方法,能快速创建,并且代码看起来更舒服。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>

	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
		<title>添加删除记录练习</title>
		<link rel="stylesheet" type="text/css" href="ex_2_style/css.css" />
		<script type="text/javascript">
		
			/*
			 * 1. 删除tr的响应函数
			 */
			function delA() {

				//点击超链接以后,需要删除超链接所在的那行
				//这里我们点击哪个超链接,this就是谁
				//获取当前tr
				var tr = this.parentNode.parentNode;

				//获取要删除的员工的名字
				//var name = tr.getElementsByTagName("td")[0].innerHTML;
				var name = tr.children[0].innerHTML;

				//删除之前弹出一个提示框
				/*
				 * confirm()用于弹出一个带有确认和取消按钮的提示框
				 * 	需要一个字符串作为参数,该字符串将会作为提示文字显示出来
				 * 如果用户点击确认则会返回true,如果点击取消则返回false
				 */
				var flag = confirm("确认删除" + name + "吗?");

				//如果用户点击确认
				if(flag) {
					//删除tr
					tr.parentNode.removeChild(tr);
				}

				/*
				 * 点击超链接以后,超链接会跳转页面,这个是超链接的默认行为,
				 * 	但是此时我们不希望出现默认行为,可以通过在响应函数的最后return false来取消默认行为
				 */
				return false;
			};

			window.onload = function() {

				/*
				 * 2. 点击超链接以后,删除一个员工的信息
				 */

				//获取所有额超链接
				var allA = document.getElementsByTagName("a");

				//为每个超链接都绑定一个单击响应函数
				for(var i = 0; i < allA.length; i++) {
					allA[i].onclick = delA;
				}

				/*
				 * 3. 添加员工的功能
				 * 	- 点击按钮以后,将员工的信息添加到表格中
				 */

				//为提交按钮绑定一个单击响应函数
				var addEmpButton = document.getElementById("addEmpButton");
				addEmpButton.onclick = function() {

					//获取用户添加的员工信息
					//获取员工的名字
					var name = document.getElementById("empName").value;
					//获取员工的email和salary
					var email = document.getElementById("email").value;
					var salary = document.getElementById("salary").value;

					//alert(name+","+email+","+salary);
					/*
					 *  <tr>
							<td>Tom</td>
							<td>tom@tom.com</td>
							<td>5000</td>
							<td><a href="javascript:;">Delete</a></td>
						</tr>
						需要将获取到的信息保存到tr中
					 */

					//创建一个tr
					var tr = document.createElement("tr");

					//设置tr中的内容
					tr.innerHTML = "<td>"+name+"</td>"+
									"<td>"+email+"</td>"+
									"<td>"+salary+"</td>"+
									"<td><a href='javascript:;'>Delete</a></td>";
									
					//获取刚刚添加的a元素,并为其绑定单击响应函数				
					var a = tr.getElementsByTagName("a")[0];
					a.onclick = delA;
					
					//获取table
					var employeeTable = document.getElementById("employeeTable");
					//获取employeeTable中的tbody
					var tbody = employeeTable.getElementsByTagName("tbody")[0];
					//将tr添加到tbodye中
					tbody.appendChild(tr);

					// 这种方式性能不好,因为会全部删除后,再创建一次,这样没必要。
					/*tbody.innerHTML += "<tr>"+
					
					"<td>"+name+"</td>"+
									"<td>"+email+"</td>"+
									"<td>"+salary+"</td>"+
									"<td><a href='javascript:;'>Delete</a></td>"
					
					+"</tr>";*/

				};

			};
		</script>
	</head>

	<body>

		<table id="employeeTable">
			<tr>
				<th>Name</th>
				<th>Email</th>
				<th>Salary</th>
				<th>&nbsp;</th>
			</tr>
			<tr>
				<td>Tom</td>
				<td>tom@tom.com</td>
				<td>5000</td>
				<td>
					<a href="javascript:;">Delete</a>
				</td>
			</tr>
			<tr>
				<td>Jerry</td>
				<td>jerry@sohu.com</td>
				<td>8000</td>
				<td>
					<a href="deleteEmp?id=002">Delete</a>
				</td>
			</tr>
			<tr>
				<td>Bob</td>
				<td>bob@tom.com</td>
				<td>10000</td>
				<td>
					<a href="deleteEmp?id=003">Delete</a>
				</td>
			</tr>
		</table>

		<div id="formDiv">

			<h4>添加新员工</h4>

			<table>
				<tr>
					<td class="word">name: </td>
					<td class="inp">
						<input type="text" name="empName" id="empName" />
					</td>
				</tr>
				<tr>
					<td class="word">email: </td>
					<td class="inp">
						<input type="text" name="email" id="email" />
					</td>
				</tr>
				<tr>
					<td class="word">salary: </td>
					<td class="inp">
						<input type="text" name="salary" id="salary" />
					</td>
				</tr>
				<tr>
					<td colspan="2" align="center">
						<button id="addEmpButton">
						Submit
					</button>
					</td>
				</tr>
			</table>

		</div>

	</body>

</html>
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

105-----JS基础-----添加删除记录-修改 的相关文章

随机推荐

  • 自定义 CSS 单位的利器

    前文 很多时候我们很想要一个能够自定义 CSS 单位的东西 比如下面这种情况 UI 妹子给的图总是 px 单位的 但是我们做移动端的时候很多时候是想要 rem 的 这时候我们会手动计算从 px 到 rem 假如你计算的是 rem px 10
  • tcpdump 抓包命令及使用

    1 抓取所有接收 发送UDP消息 不确定需求时 最好any端口 tcpdump i any udp s 0 w any pcap 2 当抓包数量太大时建议分段 C 100MB 会产生大约100MB的分段且连续的包 tcpdump i any
  • feign调用接口不稳定解决

    Caused by java net SocketException Software caused connection abort recv failed at java net SocketInputStream socketRead
  • html鼠标划过文字渐变,鼠标滑过字体颜色从左向右渐变

    鼠标滑过字体颜色从左向右渐变 html gt Document 主页 服务 关于我 主页 服务 关于我 主页 主页 服务 关于我 主页
  • leetcode -day31 Subsets I II

    1 Subsets Given a set of distinct integers S return all possible subsets Note Elements in a subset must be in non descen
  • web前端————angular1表格中的复选框、全选、反选、分页小例子

    html页面代码 table class table ordertable label table thead tr th style width 10 th tr thead table
  • Hugging Face学习

    huggingface学习 了解 案列 基础 中文文本分类任务 中文文本填空 中文关系推断 了解 Huggingface官网 link Huggingface是一个开源社区 它提供给了先进的NLP模型 数据集以及其他的工具 数据集 数据集的
  • Oauth2.0的客户端凭证模式(Client Credentials Grant)- Bad request content type. Expecting: application/x-www-

    前情摘要 最近在进行项目改造由传统Java Web项目改造为 微服务架构模式的系统 采用VUE Spring Boot Oauth2 0 JWT的主体架构 在改造过程中出现的任何异常在此做一个简单记录 以便正在路上的小伙伴们能有参照方案 在
  • 解决已将该虚拟机配置为使用 64 位客户机操作系统。但是,无法执行 64 位操作的问题。

    安装好VMware后 新建一个客户机时 错误提示 然后开始解决问题 刚开始以为是电脑上之前安装过VMware 没有卸载干净导致 然后卸载软件重装软件依然报错 最后找度娘 才解决了一堆问题 首先检查一下CPU VT x状态是否启用 是否支持虚
  • centos 7.7.1908上隐藏顶栏和任务栏

    centos 7 7 1908上隐藏顶栏和任务栏 起因 业务需求 要求客户端软件全屏显示 禁止用户操作其他界面 1 隐藏任务栏 删除 usr share gnome shell extensions window list gnome sh
  • 8个免费、高清、无版权视频素材下载网站推荐

    现如今 短视频行业可谓是风生水起 越来越多的人加入了视频剪辑 最令人头疼的就是视频素材不知道从哪里来 今天小编就给大家整合了8个免费 高清 无版权视频素材下载网站 让大家视频编辑更快捷更方便 一 Distill Distill是专为设计师提
  • 如何查看自己的电脑硬盘是不是固态硬盘

    前段时间给自己的电脑C盘换了一个固态硬盘 结果今天发现运行比较慢 就特意查了一下是不是固态的 以下是具体方法 需要的可以参考 上图红框里面得到媒体类型 显示固态硬盘它就是固态硬盘 显示其他驱动的就是机械硬盘
  • Android dip(dp) 与 sp的自适应问题

    转自 http www oschina net question 272860 70761 今天碰到的一个问题 感觉应该其他人也会碰到 拿来分享一下 我们都知道android在开发配置界面时一般都会使用dip和sp这种逻辑长度单位来实现屏幕
  • Matlab 中prod函数的使用

    B prod A 将A矩阵不同维的元素的乘积返回到矩阵B Matlab中文论坛 如果A是向量 prod A 返回A向量的乘积 如果A是矩阵 prod A 将A看作列向量 返回每一列元素的乘积并组成一个行向量B 如果A是多维数组 prod A
  • jenkins_获取json

    import jenkins import yaml import json import urllib parse import xmltodict from xml etree import ElementTree def LoginJ
  • ubuntu 16.04 编译与安装 absl 库(cartographer库安装之1-absl)

    set o errexit set o verbose git clone https github com abseil abseil cpp git cd abseil cpp git checkout d902eb869bcfacc1
  • 【CTF】web-文件上传篇1

    upload labs靶场 1 前端js限制 2 修改Content Type 3 htaccess绕过 4 00截断 1 前端js限制 场景 使用 burp 抓包 在点击上传时 直接弹出了提示 这时 burp 并没有抓到数据包 说明是在前
  • 深度学习常用Linux命令

    Linux命令查询手册 https www linuxcool com 目录 一 常用快捷键 二 关于docker的使用 1 进入docker 2 设置使用某块dcu代码 3 docker与主机之间的文件传输 三 关于文件和文件夹 1 文件
  • ADS错误之the session file 'C:\user\username\default-1-2-0-0.ses' could not be loaded

    刚在编arm程序的时候遇到了这个错误 去网上搜了下资料 查到关于这个错误信息的解决方法 如下 如果出现错误信息 the session file C user username default 1 2 0 0 ses could not b
  • 105-----JS基础-----添加删除记录-修改

    一 代码 本节的代码是对104节的内容进行优化 因为按照上一节的内容这样写的话 会创建过多的资源 造成资源浪费 导致用户体验不好 当界面复杂起来 可能会变得很卡 造成用户体验不好 所以需要进行优化 下面的例子 避免了人为的创建多个节点元素