HTML中表格动态添加_动力节点Java学院整理
废话不多说了,直接给大家贴代码了,具体代码如下所示:
<html>
<head><title>Table</title></head>
<body>
<table border="1">
<thead>
<tr>
<td>First Name</td>
<td>Last Name</td>
<td> </td>
</tr>
<thead>
<tbody id="tb">
<tr id="1st">
<td>张</td>
<td>三</td>
<td><input type="button" value="Add" onclick="add()">
<input type="button" value="Del" onclick="del(this)"></td>
</tr>
</tbody>
</table>
</body>
</html>
<script>
function add() {
var trObj = document.createElement("tr");
trObj.id = new Date().getTime();
trObj.innerHTML = "<td><input name='firstName'/></td><td><input name='lastName'/></td><td><input type='button' value='Add' onclick='add()'> <input type='button' value='Del' onclick='del(this)'></td>";
document.getElementById("tb").appendChild(trObj);
}
function del(obj) {
var trId = obj.parentNode.parentNode.id;
var trObj = document.getElementById(trId);
document.getElementById("tb").removeChild(trObj);
}
</script>上面的代码中,首先在body中构造了一个table,为了方便后续的操作,我们给table添加了thead 和 tbody 标签,thead标签标示的是表格头,tbody标签标示的是表格主体。
示例中的表格,共有三列,第一列 first name,第二列 last name,第三列为操作列。
操作列中,包含两个操作,一个是给表格添加行,一个是删除当前行。添加行和删除行的操作分别绑在两个按钮上,点击按钮时,触发相应的添加行/ 删除行 操作。
添加行方法
function add() {
var trObj = document.createElement("tr");
trObj.id = new Date().getTime();
trObj.innerHTML = "<td><input name='firstName'/></td><td><input name='lastName'/></td><td><input type='button' value='Add' onclick='add()'> <input type='button' value='Del' onclick='del(this)'></td>";
document.getElementById("tb").appendChild(trObj);
}第一行,创建tr元素,即创建一个表格行。
第二行,trObj.id = new Date().getTime(); 给改行添加id 属性,并给属性赋值,取当前系统的毫秒数,这个主要是删除的时候需要。
第三行,trObj.innerHTML = "<td><input name='firstName'/></td><td><input name='lastName'/></td><td><input type='button' value='Add' onclick='add()'>
<input type='button' value='Del' onclick='del(this)'></td>"; 给表格行赋值,通过innerHTMML属性,设置<tr>标签和</tr> 标签间的html代码内容,也就是要添加的行内容。
第四行,document.getElementById("tb").appendChild(trObj); 将创建好的表格行添加到表格主体中。
删除行方法
function del(obj) {
var trId = obj.parentNode.parentNode.id;
var trObj = document.getElementById(trId);
document.getElementById("tb").removeChild(trObj);
}删除方法中传递了一个参数,在添加行方法中,我们可以看到删除方法del 中传递了this参数,页面代码中的this指代的是当前的HTML元素,即this所在的<input >域。
第一行,var trId = obj.parentNode.parentNode.id; 获取当前元素的父节点的父节点的id,即要删除的行的id 。
第二行,var trObj = document.getElementById(trId); 获取要删除的行元素。
第三行,document.getElementById("tb").removeChild(trObj); 在表格主体中删除该行。
瑕疵
上面的代码基本实现了动态给表格增加行和删除行的功能,但是代码还有瑕疵,主要有这么两点:
1 表格在增加行前和增加行后,表格宽度发生变化
增加行前

增加行后

增加行后,表格列变宽了
2 浏览器默认打开的页面中文出现乱码

需要 设置字符编码修改页面编码格式后才能正常显示
栏 目:HTML/Xhtml
本文地址:https://fushidao.cc/wangyezhizuo/223.html
您可能感兴趣的文章
- 03-07如何轻松入门并高效制作专业的HTML5网页?零基础怎么学?
- 03-06HTML和CSS怎么制作网页?新手如何快速上手?
- 03-06如何通过HTML高效制作并优化腾讯网页设计,腾讯网页设计怎么做?
- 02-28HTML代码怎么制作网页?网页设计核心要素有哪些
- 02-28网页制作HTML代码怎么写,零基础入门详细教程
- 02-28HTML学习过程中有哪些常见疑问与难题?零基础怎么学?
- 02-28HTML网页制作如何掌握高效技巧,怎么轻松打造专业级网页?
- 02-28HTML网页怎么制作优化,如何提升搜索引擎排名?
- 02-28HTML网页制作代码如何高效学习,零基础入门到精通怎么做?
- 02-28HTML5网页制作怎么学?高效掌握技巧有哪些?
阅读排行
推荐教程
- 02-01HTML制作网页代码,新手如何从零开始打造专业网站?
- 09-112025年9月网页制作:HTML与XHTML的最新代码
- 02-19HTML中表格动态添加_动力节点Java学院整理
- 02-19HTML标签meta总结,HTML5 head meta 属性整理
- 12-14HTML表格合并的具体实现方式
- 02-19html 基于 canvas 实现的一个截图小demo
- 02-195种做法实现table表格中的斜线表头效果
- 02-19HTML网页中插入视频的方法小结
- 02-19html中关于form与表单提交操作的资料集合
- 02-19快速解决input[type=file]打开时慢、卡顿的问题
