HTML中表格動態(tài)添加_動力節(jié)點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中構(gòu)造了一個table,為了方便后續(xù)的操作,我們給table添加了thead 和 tbody 標簽,thead標簽標示的是表格頭,tbody標簽標示的是表格主體。
示例中的表格,共有三列,第一列 first name,第二列 last name,第三列為操作列。
操作列中,包含兩個操作,一個是給表格添加行,一個是刪除當前行。添加行和刪除行的操作分別綁在兩個按鈕上,點擊按鈕時,觸發(fā)相應(yīng)的添加行/ 刪除行 操作。
添加行方法
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); }
第一行,創(chuàng)建tr元素,即創(chuàng)建一個表格行。
第二行,trObj.id = new Date().getTime();
給改行添加id 屬性,并給屬性賦值,取當前系統(tǒng)的毫秒數(shù),這個主要是刪除的時候需要。
第三行,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屬性,設(shè)置<tr>標簽和</tr> 標簽間的html代碼內(nèi)容,也就是要添加的行內(nèi)容。
第四行,document.getElementById("tb").appendChild(trObj);
將創(chuàng)建好的表格行添加到表格主體中。
刪除行方法
function del(obj) { var trId = obj.parentNode.parentNode.id; var trObj = document.getElementById(trId); document.getElementById("tb").removeChild(trObj); }
刪除方法中傳遞了一個參數(shù),在添加行方法中,我們可以看到刪除方法del 中傳遞了this參數(shù),頁面代碼中的this指代的是當前的HTML元素,即this所在的<input >域。
第一行,var trId = obj.parentNode.parentNode.id
; 獲取當前元素的父節(jié)點的父節(jié)點的id,即要刪除的行的id 。
第二行,var trObj = document.getElementById(trId);
獲取要刪除的行元素。
第三行,document.getElementById("tb").removeChild(trObj);
在表格主體中刪除該行。
瑕疵
上面的代碼基本實現(xiàn)了動態(tài)給表格增加行和刪除行的功能,但是代碼還有瑕疵,主要有這么兩點:
1 表格在增加行前和增加行后,表格寬度發(fā)生變化
增加行前
增加行后
增加行后,表格列變寬了
2 瀏覽器默認打開的頁面中文出現(xiàn)亂碼
需要 設(shè)置字符編碼修改頁面編碼格式后才能正常顯示
相關(guān)文章
jQuery JSON動態(tài)獲取表格數(shù)據(jù)特效源碼
jQuery JSON動態(tài)獲取表格數(shù)據(jù)特效源碼是一款jQuery函數(shù)調(diào)用json表格動態(tài)獲取數(shù)據(jù),表格全部折疊,全部關(guān)閉,雙擊表格行折疊關(guān)閉表格。本段特效源碼可以在各大網(wǎng)站使用,有2017-07-06- Excel表格中怎么制作一個柱形動態(tài)圖表?excel表格中數(shù)據(jù)很多,想要按月份制作一個動態(tài)圖標,該怎么制作呢?下面我們就來看看詳細的教程,需要的朋友可以參考下2017-06-28
Excel表格中怎么制作帶復(fù)選框的動態(tài)圖表?
Excel表格中怎么制作帶復(fù)選框的動態(tài)圖表?excel數(shù)據(jù)生成動態(tài)圖表,但是數(shù)據(jù)太多了,看上去很亂,該怎么辦呢?下面我們就來看看動態(tài)圖表添加復(fù)選框的教程,需要的朋友可以參2016-12-19jquery實現(xiàn)的超帥動態(tài)表格交叉變色高亮顯示效果
鼠標滑過表格時可以控制表格行、列或者交叉變色高亮顯示2013-06-17WPS為查看費力多數(shù)據(jù)表格改為動態(tài)數(shù)據(jù)顯示技巧步驟
傳統(tǒng)的圖表設(shè)計方式往往在多數(shù)據(jù)系列時查看起來比較費力。2011-12-23Sigma Grid實現(xiàn)ajax動態(tài)表格(支持分頁、列寬拖動、數(shù)據(jù)排序)
Sigma Grid 核心基于javascript、ajax,顯示樣式全部有CSS控制,可自定義多種顯示風格,官方提供UI編輯器,支持鼠標拖動列寬、數(shù)據(jù)行排序,動態(tài)分頁等功能,可廣泛適用于C2010-02-10- 如果能做一個動態(tài)表頭,將所有標題需要變動的部分做成單元格的引用,只要改動一處,所有的標題將一起跟著改變,這樣就方便多了。2010-02-07