网页表格的动态添加代码分享

今天分享下”网页表格的动态添加代码分享“这篇文章,文中根据实例编码详细介绍,或许对大家的编程之路有着一定的参考空间与使用价值,需要的朋友接下来跟着云南仟龙Mark一起学习一下吧。

废话不多说了,直接给大家贴代码了,具体代码如下所示:

​​<​​​​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(​​http://www.qlyl1688.com/​​) { ​​

​​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,第三列为操作列。

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

添加行方法

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 = "​​

​​​​"; 给表格行赋值,通过innerHTMML属性,设置标签和 标签间的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所在的域。

第一行,​​var trId = obj.parentNode.parentNode.id​​; 获取当前元素的父节点的父节点的id,即要删除的行的id 。

第二行,​​var trObj = document.getElementById(trId); ​​获取要删除的行元素。

第三行,​​document.getElementById(“tb”).removeChild(trObj); ​​在表格主体中删除该行。

瑕疵

上面的代码基本实现了动态给表格增加行和删除行的功能,但是代码还有瑕疵,主要有这么两点:

1 表格在增加行前和增加行后,表格宽度发生变化

增加行前

在这里插入图片描述

增加行后

在这里插入图片描述

增加行后,表格列变宽了

2 浏览器默认打开的页面中文出现乱码

在这里插入图片描述

需要 设置字符编码修改页面编码格式后才能正常显示

以上是云南仟龙Mark给大家介绍的所有内容,希望对大家有所帮助,如果大家有任何疑问请在脚本之家留言,如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值