104-----JS基础-----添加删除记录-添加

一 代码

下面以基础的方法来讲述,为了更好的讲解更多的函数。
但是开发时尽量不用这么麻烦,因为耗资源,建议使用下一节的优化的代码做,使代码效率更高。

<!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() {

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

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

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

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

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

			window.onload = function() {

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

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

				// 2) 为每个超链接都绑定一个单击响应函数
				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");

					//创建四个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 = delA;

					//获取table
					var employeeTable = document.getElementById("employeeTable");
					//获取employeeTable中的tbody
					var tbody = employeeTable.getElementsByTagName("tbody")[0];
					//将tr添加到tbodye中
					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">
						Submit
					</button>
					</td>
				</tr>
			</table>

		</div>

	</body>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现搜索历史记录和去重、缓存,可以使用uni-app提供的本地存储功能。 首先,需要定义一个对象用来保存搜索历史记录,例如: ```javascript const history = { list: [], // 保存搜索历史的数组 maxLen: 10, // 最大历史记录数 add(keyword) { // 添加历史记录的方法 const index = this.list.indexOf(keyword) if (index !== -1) { this.list.splice(index, 1) // 如果已存在该记录则先删除 } this.list.unshift(keyword) // 添加到数组头部 if (this.list.length > this.maxLen) { this.list.pop() // 如果超过最大长度则删除末尾记录 } }, clear() { // 清空历史记录的方法 this.list = [] } } ``` 然后,可以在搜索框的输入事件中调用 add 方法,将搜索关键字添加到历史记录中。同时,在页面加载时可以从本地存储中读取历史记录,例如: ```javascript onLoad() { const historyList = uni.getStorageSync('history') || [] // 从本地存储中读取历史记录 history.list = historyList // 覆盖 history 对象的 list 属性 } ``` 为了防止用户重复添加同一条历史记录,可以在 add 方法中先通过 indexOf 方法判断该记录是否已存在,如果存在则先删除原有记录。 ```javascript add(keyword) { // 添加历史记录的方法 const index = this.list.indexOf(keyword) if (index !== -1) { this.list.splice(index, 1) // 如果已存在该记录则先删除 } this.list.unshift(keyword) // 添加到数组头部 if (this.list.length > this.maxLen) { this.list.pop() // 如果超过最大长度则删除末尾记录 } } ``` 最后,为了实现历史记录的缓存功能,可以在 add 和 clear 方法中调用 uni.setStorageSync 方法将历史记录保存到本地存储中,例如: ```javascript add(keyword) { // 添加历史记录的方法 // ... uni.setStorageSync('history', this.list) // 将历史记录保存到本地存储中 }, clear() { // 清空历史记录的方法 this.list = [] uni.setStorageSync('history', this.list) // 将清空后的历史记录保存到本地存储中 } ``` 这样就可以实现搜索历史记录和去重、缓存的功能了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值