【JavaScript】DOM操作表格

简介:
+关注继续查看
DOM操作表格

1.利用JavaScript动态增加、删除表格内容

页面如图



注:首先说个小问题,有些如制定按钮点击事件的js代码,放在html文档最后可以,放在最前面(<head>标签内)不可以,原因是html文档是自上往下读取,当读到最上面的js、代码时,并没有读取相应的DOM标签,所以制定的按钮功能没有效果,如果非要放在上面,可以指定到window.onload方法中去:
<head>
<span style="white-space:pre">	</span><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
	<title>js测试</title>
	<script language="javascript">
	        //window.onload执行规则:
		//1.必须dom结构绘制完毕(整个html解析结束)之后才执行
		//2.页面的所有关联的文件必须加载完毕
		window.onload=function(){
			//<button id="addUser">提交</button>
			document.getElementById("addUser").onclick=function(){
				alert("xxxx");
			};
		}
	</script>
</head>

言归正传,咱们来实现刚刚说的动态增删表格功能

实现:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
		<title>js测试</title>
		
	</head>
	<body> 
	   
	    <center>
			<br><br>
			添加用户:<br><br>
			姓名: <input type="text" name="name" id="name" />  
			email: <input type="text" name="email" id="email" />  
			电话: <input type="text" name="tel" id="tel" /><br><br>
			<button id="addUser">提交</button>
			<br><br>
			<hr>
			<br><br>
			<table id="usertable" border="1" cellpadding="5" cellspacing=0>
				<tbody>
					<tr>
						<th>姓名</th>
						<th>email</th>
						<th>电话</th>
						<th> </th>
					</tr>
					<tr>
						<td>Tom</td>
						<td>tom@tom.com</td>
						<td>5000</td>
						<td><a href="deleteEmp?id=Tom">Delete</a></td>
					</tr>
					<tr>
						<td>Jerry</td>
						<td>jerry@sohu.com</td>
						<td>8000</td>
						<td><a href="deleteEmp?id=Jerry">Delete</a></td>
					</tr>
				</tbody>
			</table>
		</center>
	</body>
	<script language="javascript">
		//window.onload执行规则:
		//1.必须dom结构绘制完毕(整个html解析结束)之后才执行
		//2.页面的所有关联的文件必须加载完毕
		window.onload=function(){
			//<button id="addUser">提交</button>
			document.getElementById("addUser").onclick=function(){
				/****************************************************/
				//获取文本框的值
				var name=document.getElementById("name").value;
				var email=document.getElementById("email").value;
				var tel=document.getElementById("tel").value;
				
				/****************************************************/
				//创建四个<td>,并加入文本值
				var nameTd=document.createElement("td");
				var nameText=document.createTextNode(name);
				nameTd.appendChild(nameText);
				var emailTd=document.createElement("td");
				var emailText=document.createTextNode(email);
				emailTd.appendChild(emailText);
				var telTd=document.createElement("td");
				var telText=document.createTextNode(tel);
				telTd.appendChild(telText);
				
				//创建超链接标签
				var aTd=document.createElement("td");
				var aElement=document.createElement("a");
				aElement.setAttribute("href","deleteEmp?id="+name);
				var deleteText=document.createTextNode("Delete");
				aElement.appendChild(deleteText);
				aTd.appendChild(aElement);
				
				/****************************************************/
				//创建<tr>
				var trElement=document.createElement("tr");
				
				//增加<td>到<tr>上
				trElement.appendChild(nameTd);
				trElement.appendChild(emailTd);
				trElement.appendChild(telTd);
				trElement.appendChild(aTd);
				
				/****************************************************/
				//增加<tr>到<table>上
				var tableElement=document.getElementById("usertable");
				//tableElement.appendChild(trElement);
				//由于部分IE浏览器显示不正常,为了兼容性,添加到tbody标签上
				//创建tbody,为了跨浏览器显示
				var tbodyElement=document.createElement("tbody");
				tbodyElement.appendChild(trElement);
				
				//放置tbody到table上
				tableElement.appendChild(tbodyElement);
				
				/****************************************************/
				//删除
				aElement.onclick=function(){
					//return false使网页的链接失效
					return delTr(aElement);
				}
				
				/****************************************************/
				function delTr(aELement){
					var name=aElement.parentNode.parentNode.firstChild.firstChild.nodeValue;
					var flag=window.confirm("您真的要删除["+name+"]吗?");
					//点击"取消"按钮
					if(!flag){
						return false;
					}
					
					/*删除*********************************************/
					//获取tbody
					var tbodyElement=aElement.parentNode.parentNode.parentNode;
					//获取tr
					var trElement=aElement.parentNode.parentNode;
					//删除
					tbodyElement.removeChild(trElement);
					//使网页的链接失效
					return false;
				}
			}
		}
		
	</script>
</html>

最终效果:
点击添加,添加成功!

点击"Delete"链接,删除成功!

转载请注明出处:http://blog.csdn.net/acmman/article/details/48010081

相关文章
|
13小时前
|
JavaScript 前端开发
JAVAScript Dom总结
JAVAScript Dom总结
|
8天前
|
XML JavaScript 前端开发
JavaScript函数和BOM及DOM编程(详细总结-无尿点)(二)
JavaScript函数和BOM及DOM编程(详细总结-无尿点)(二)
12 0
|
8天前
|
存储 JavaScript 前端开发
JavaScript函数和BOM及DOM编程(详细总结-无尿点)(一)
JavaScript函数和BOM及DOM编程(详细总结-无尿点)(一)
13 0
|
8天前
|
XML 缓存 JavaScript
JavaScript操作DOM常用的API
1 什么是DOM 文档对象模型 (DOM) 是HTML和XML文档的编程接口。它提供了对文档的结构化的表述,并定义了一种方式可以使从程序中对该结构进行访问,从而改变文档的结构,样式和内容。文档对象模型 (DOM) 是对HTML文件的另一种展示,通俗地说,一个HTML 文件,我们可以用编辑器以代码的形式展示它,也可以用浏览器以页面的形式展示它,同一份文件通过不同的展示方式,就有了不一样的表现形式。而DOM 将文档解析为一个由节点和对象(包含属性和方法的对象)组成的结构集合。简言之,它会将web页面和脚本或程序语言连接起来,我们可以使用脚本或者程序语言通过DOM 来改变或者控制web页面。
12 0
|
10天前
|
JavaScript 前端开发
JavaScript 进阶5:WebAPI:DOM- 网页特效篇
JavaScript 进阶5:WebAPI:DOM- 网页特效篇
14 0
|
15天前
|
JavaScript 前端开发
JS中DOM编程获取与操作元素
JS中DOM编程获取与操作元素
14 0
|
15天前
|
XML 编解码 JavaScript
JS中的BOM和DOM的介绍与使用
JS中的BOM和DOM的介绍与使用
15 0
|
19天前
|
XML JavaScript 前端开发
【JavaWeb】知识总结Ⅳ(JavaScript中的DOM)
JavaScript 能改变页面中的所有 HTML 元素 JavaScript 能改变页面中的所有 HTML 属性 JavaScript 能改变页面中的所有 CSS 样式 JavaScript 能删除已有的 HTML 元素和属性 JavaScript 能添加新的 HTML 元素和属性 JavaScript 能对页面中所有已有的 HTML 事件作出反应 JavaScript 能在页面中创建新的 HTML 事件
|
29天前
|
JavaScript 前端开发
JavaScript基础(Dom操作)(三)
JavaScript基础(Dom操作)
|
29天前
|
JavaScript 前端开发 Go
JavaScript基础(Dom操作)(二)
JavaScript基础(Dom操作)
相关产品
云迁移中心
推荐文章
更多