HTML中表格動(dòng)態(tài)添加
廢話不多說了,直接給大家貼代碼了,具體代碼如下所示:
<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)造了一個(gè)table,為了方便后續(xù)的操作,我們給table添加了thead 和 tbody 標(biāo)簽,thead標(biāo)簽標(biāo)示的是表格頭,tbody標(biāo)簽標(biāo)示的是表格主體。
示例中的表格,共有三列,第一列 first name,第二列 last name,第三列為操作列。
操作列中,包含兩個(gè)操作,一個(gè)是給表格添加行,一個(gè)是刪除當(dāng)前行。添加行和刪除行的操作分別綁在兩個(gè)按鈕上,點(diǎn)擊按鈕時(shí),觸發(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)建一個(gè)表格行。
第二行,trObj.id = new Date().getTime();
給改行添加id 屬性,并給屬性賦值,取當(dāng)前系統(tǒng)的毫秒數(shù),這個(gè)主要是刪除的時(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>標(biāo)簽和</tr> 標(biāo)簽間的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); }
刪除方法中傳遞了一個(gè)參數(shù),在添加行方法中,我們可以看到刪除方法del 中傳遞了this參數(shù),頁面代碼中的this指代的是當(dāng)前的HTML元素,即this所在的<input >域。
第一行,var trId = obj.parentNode.parentNode.id
; 獲取當(dāng)前元素的父節(jié)點(diǎn)的父節(jié)點(diǎn)的id,即要?jiǎng)h除的行的id 。
第二行,var trObj = document.getElementById(trId);
獲取要?jiǎng)h除的行元素。
第三行,document.getElementById("tb").removeChild(trObj);
在表格主體中刪除該行。
瑕疵
上面的代碼基本實(shí)現(xiàn)了動(dòng)態(tài)給表格增加行和刪除行的功能,但是代碼還有瑕疵,主要有這么兩點(diǎn):
1 表格在增加行前和增加行后,表格寬度發(fā)生變化
增加行前
增加行后
增加行后,表格列變寬了
2 瀏覽器默認(rèn)打開的頁面中文出現(xiàn)亂碼
需要 設(shè)置字符編碼修改頁面編碼格式后才能正常顯示
上一篇:關(guān)于table表格中的內(nèi)容溢出布局方法
欄 目:CSS/HTML
下一篇:關(guān)于div中img,span垂直居中的問題
本文標(biāo)題:HTML中表格動(dòng)態(tài)添加
本文地址:http://mengdiqiu.com.cn/a1/CSS_HTML/9587.html
您可能感興趣的文章
- 04-02表格樣式css樣式,css樣式表單
- 04-02好看的字體樣式css,好看的字體樣式圖片
- 04-02html中加入css樣式的簡單介紹
- 04-02內(nèi)嵌樣式css,內(nèi)嵌樣式表,內(nèi)部樣式表,外部樣式表中優(yōu)先級最高的
- 04-02vue中的css樣式布局,vue添加css樣式
- 01-10利用iframe在網(wǎng)頁中顯示天氣附效果截圖
- 01-10通過html為FLASH加鏈接的實(shí)現(xiàn)代碼(div層)
- 01-10a標(biāo)簽中寫有文字如何隱藏文字顯示圖片兼容360模式渲染
- 01-10IE瀏覽器HTML Hack標(biāo)簽總結(jié)
- 01-10html用style添加屬性示例


閱讀排行
本欄相關(guān)
- 04-02表格樣式css樣式,css樣式表單
- 04-02好看的字體樣式css,好看的字體樣式圖
- 04-02分頁樣式css,分頁樣式j(luò)q
- 04-02分頁樣式css,分頁樣式欄里用來定義首
- 04-02css樣式的引入,css樣式怎么引入
- 04-02css滾動(dòng)條樣式,css滾動(dòng)條的樣式
- 04-02css樣式引入方式有幾種,網(wǎng)頁引入css樣
- 04-02html中加入css樣式的簡單介紹
- 04-02vue中的css樣式布局,vue添加css樣式
- 04-02內(nèi)嵌樣式css,內(nèi)嵌樣式表,內(nèi)部樣式表
隨機(jī)閱讀
- 01-11常用的HTML富文本編譯器UEditor、CKEdi
- 01-10C++實(shí)現(xiàn)將數(shù)組中的值反轉(zhuǎn)
- 01-10C語言打印楊輝三角示例匯總
- 08-05織夢dedecms首頁調(diào)用縮略圖為背景
- 01-10vue實(shí)現(xiàn)分頁加載效果
- 08-05dedecms織夢模板全站調(diào)用收藏?cái)?shù)的方法
- 08-05DEDECMS點(diǎn)擊主欄目默認(rèn)顯示第一個(gè)子欄
- 01-10C++ 類訪問控制的條件總結(jié)
- 01-10bat批處理徹底隱藏文件的方法(使用
- 08-05dedecms織夢模板編輯文檔的同時(shí)自動(dòng)更