HTML中表格动态添加的方法


当前第2页 返回上一页

示例中的表格,共有三列,第一列 first name,第二列 last name,第三列为操作列。

操作列中,包含两个操作,一个是给表格添加行,一个是删除当前行。添加行和删除行的操作分别绑在两个按钮上,点击按钮时,触发相应的添加行/ 删除行 操作。

添加行方法

1

2

3

4

5

6

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); 将创建好的表格行添加到表格主体中。

删除行方法

1

2

3

4

5

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中的超级链接<a>标签

html标签中lang的作用

用html中标签制作表单实例

以上就是HTML中表格动态添加的方法的详细内容,更多文章请关注木庄网络博客

返回前面的内容

相关阅读 >>

怎么实现Html 可输入下拉菜单

focus在Html是什么意思

Html中position有哪些用法?position的用法介绍

Html address标签怎么用

Html怎么设置段距

Html怎么首行缩进

Html ins标签常用的用法有哪些?Html ins常用属性的介绍

Html的a标签href属性指定相对路径与绝对路径的用法讲解

Html链接的功能

Html如何设置网页标题?

更多相关阅读请进入《Html》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...