103-105 添加删除记录

添加删除记录

DOM删除

  • removeChild()

删除子节点

  • confirm()

用于弹出一个带有确认和取消按钮的提示框,需要一个字符串作为参数,改字符串将会作为提示文字显示出来,如果用户点击确认会返回true,果果点击取消返回false

html 复制代码
<!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="css.css" />
<script type="text/javascript">
	function  deleteA(){
		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(){
		//获取所有额超链接
		var allA = document.getElementsByTagName("a");
		
		//为每个超链接都绑定一个单击响应函数
		for(var i=0 ; i < allA.length ; i++) {
			allA[i].onclick = deleteA;
		}
		var addEmpButton =document.getElementById("addEmpButton");
		addEmpButton.onclick =function (){
		var empName =document.getElementById("empName").value;
		var email =document.getElementById("email").value;
		var salary =document.getElementById("salary").value;

		// var a =document.createElement("a");
		// a.innerText ="Delete";


		var tr =document.createElement("tr");
		// var nameTd =document.createElement("td");
		// var emailTd =document.createElement("td");
		// var salaryTd =document.createElement("td");
		// var aTd =document.createElement("td");
			tr.innerHTML ="<td>"+empName+"</td>"+
					      "<td>"+email+"</td>"+
					      "<td>"+salary+"</td>"+
						  "<td><a href='javascript:;'>Delete</a></td>";
			var a =tr.getElementsByTagName("a")[0];//哪怕只有一个元素,该方法也会返回一个集合
			a.onclick =deleteA;

		// var nameText =document.createTextNode(empName);
		// var emailText =document.createTextNode(email);
		// var salaryText =document.createTextNode(salary);
		// var delText =document.createTextNode("delete");
		//
		//
		// // a.appendChild(delText);上面有innerText
		// a.href ="javascript:;";
		// aTd.appendChild(a);
		// nameTd.appendChild(nameText);
		// emailTd.appendChild(emailText);
		// salaryTd.appendChild(salaryText);
		//
		// tr.appendChild(nameTd);
		// tr.appendChild(emailTd);
		// tr.appendChild(salaryTd);
		// tr.appendChild(aTd);

		var employeeTable =document.getElementById("employeeTable");
		var tbody =employeeTable.getElementsByTagName("tbody")[0];
		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>
相关推荐
徐小夕2 小时前
知识库创业复盘:从闭源到开源,这3个教训价值百万
前端·javascript·github
xhxxx2 小时前
函数执行完就销毁?那闭包里的变量凭什么活下来!—— 深入 JS 内存模型
前端·javascript·ecmascript 6
StarkCoder3 小时前
求求你试试 DiffableDataSource!别再手算 indexPath 了(否则迟早崩)
前端
fxshy3 小时前
Cursor 前端Global Cursor Rules
前端·cursor
红彤彤3 小时前
前端接入sse(EventSource)(@fortaine/fetch-event-source)
前端
L、2183 小时前
统一日志与埋点系统:在 Flutter + OpenHarmony 混合架构中实现全链路可观测性
javascript·华为·智能手机·electron·harmonyos
WindStormrage3 小时前
umi3 → umi4 升级:踩坑与解决方案
前端·react.js·cursor
用户47949283569153 小时前
面试官:DNS 解析过程你能说清吗?DNS 解析全流程深度剖析
前端·后端·面试