JS:添加删除练习

本文介绍如何使用JavaScript操作DOM实现网页上员工信息的动态增删功能,包括通过confirm弹窗确认删除操作,以及两种添加员工信息的方法,一种是手动创建DOM元素,另一种是直接设置tr的innerHTML。
实现图片中的Delete和Submit功能

在这里插入图片描述

https://www.w3school.com.cn/jsref/dom_obj_window.asp

1.点击超链接以后,删除一个员工的信息
  • confirm()用于弹出一个带有确认和取消按钮的提示框
    • 需要一个字符串作为参数,该字符串将会作为提示文字显示出来
    • 如果用户点击确认则会返回true,如果点击取消则返回false
  • 点击超链接以后,超链接会跳转页面,这个是超链接的默认行
    • 但是此时我们不希望出现默认行为,可以通过在响应函数的最后return false来取消默认行为
/*
		 * 点击超链接以后,删除一个员工的信息
		 */
		//获取所有额超链接
		var allA = document.getElementsByTagName("a");
		//为每个超链接都绑定一个单击响应函数
		for(var i=0 ; i < allA.length ; i++){
			allA[i].onclick = function(){
				
				//点击超链接以后需要删除超链接所在的那行
				//这里我们点击那个超链接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;
			};
		}

2.添加员工功能

方法一:比较复杂

/*
		添加员工功能
		点击按钮后,将信息添加到表格中
		*/
		var addEmpButton = document.getElementById("addEmpButton");
		addEmpButton.onclick = function(){
			//获取用户添加的员工信息
			
			//获取员工的名字\email\salary
			var name = document.getElementById("empName").value;
			var email = document.getElementById("email").value;
			var salary = document.getElementById("salary").value;
			console.log(name+email+salary);
			
			/*封装成如下结构
			<tr>
				<td>Bob</td>
				<td>bob@tom.com</td>
				<td>10000</td>
				<td><a href="deleteEmp?id=003">Delete</a></td>
			</tr>			
			*/
		   //创建tr
		   var tr = document.createElement("tr");
		   //创建4个td
		   var nameTd = document.createElement("td");
		   var emailTd = document.createElement("td");
		   var salaryTd = document.createElement("td");
		   var aTd = document.createElement("td");
		   //创建一个a元素
		   var a = document.createElement("a");
		   //创建文本节点
		   var nameText = document.createTextNode(name);
		   var emailText = document.createTextNode(email);
		   var salaryText = document.createTextNode(salary);
		   var delText = document.createTextNode("Delete");
		   
		   //将文本添加到td中
		   nameTd.appendChild(nameText);
		   emailTd.appendChild(emailText);
		   salaryTd.appendChild(salaryText);
		   
		   //向a中添加文本
		   a.appendChild(delText);
		   //将a添加到td中
		   aTd.appendChild(a);
		   
		   //将td添加到tr中
		   tr.appendChild(nameTd);
		   tr.appendChild(emailTd);
		   tr.appendChild(salaryTd);
		   tr.appendChild(aTd);
		   
		   //向a中添加href属性
		   a.href = "javascript:;";
		   //为新添加的a再绑定一次单击响应函数
		   a.onclick = function(){
			   var tr = this.parentNode.parentNode;
			   var name = tr.children[0].innerHTML;
			   var flag = confirm("确认删除"+name+"吗?");
			   if(flag){
			   	tr.parentNode.removeChild(tr);
			   }
			   return false;
		   };
		   
		   //获取table 
		   var employeeTable = document.getElementById("employeeTable");
		   //获取employeeTable中的tbody,tbody是由浏览器产生的
		   var tbody = employeeTable.getElementsByTagName("tbody")[0];
		   //将tr添加到tbody中
		   tbody.appendChild(tr);
		};

在这里插入图片描述

  • 方法二:
<!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">
	
	window.onload = function(){
		
		/*
		 * 点击超链接以后,删除一个员工的信息
		 */
		//获取所有额超链接
		var allA = document.getElementsByTagName("a");
		//为每个超链接都绑定一个单击响应函数
		for(var i=0 ; i < allA.length ; i++){
			allA[i].onclick = function(){
				
				//点击超链接以后需要删除超链接所在的那行
				//这里我们点击那个超链接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;
			};
		}
		
		/*
		添加员工功能
		点击按钮后,将信息添加到表格中
		*/
		var addEmpButton = document.getElementById("addEmpButton");
		addEmpButton.onclick = function(){
			//获取用户添加的员工信息
			
			//获取员工的名字\email\salary
			var name = document.getElementById("empName").value;
			var email = document.getElementById("email").value;
			var salary = document.getElementById("salary").value;
			console.log(name+email+salary);
			
			/*封装成如下结构
			<tr>
				<td>Bob</td>
				<td>bob@tom.com</td>
				<td>10000</td>
				<td><a href="deleteEmp?id=003">Delete</a></td>
			</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>";
			var a = tr.getElementsByTagName("a")[0];
			a.onclick = function(){
				var tr = this.parentNode.parentNode;
				var name = tr.children[0].innerHTML;
				var flag = confirm("确认删除"+name+"吗?");
				if(flag){
					//删除tr
					tr.parentNode.removeChild(tr);
				}
				return false;
			};
			//获取table
			var employeeTable = document.getElementById("employeeTable");
			//获取employeeTable中的<tbody>
			var tbody = employeeTable.getElementsByTagName("tbody")[0];
			//将tr添加到tbody中
			tbody.appendChild(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" value="abc">
						Submit
					</button>
				</td>
			</tr>
		</table>

	</div>

</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值