国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > HTML > 正文

HTML中表格動態添加_動力節點Java學院整理

2024-08-26 00:19:48
字體:
來源:轉載
供稿:網友

廢話不多說了,直接給大家貼代碼了,具體代碼如下所示:

<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  表格在增加行前和增加行后,表格寬度發生變化

增加行前

html,動態添加表格,表格動態添加

增加行后

html,動態添加表格,表格動態添加

增加行后,表格列變寬了

2  瀏覽器默認打開的頁面中文出現亂碼

html,動態添加表格,表格動態添加

需要 設置字符編碼修改頁面編碼格式后才能正常顯示


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿克苏市| 浦北县| 砚山县| 曲水县| 铜陵市| 东乡族自治县| 杭州市| 大城县| 永寿县| 政和县| 英德市| 文安县| 盐津县| 中宁县| 榆社县| 广宁县| 水富县| 唐河县| 太湖县| 察哈| 广西| 临澧县| 建平县| 襄垣县| 弥渡县| 延津县| 邮箱| 马龙县| 安图县| 曲麻莱县| 淳化县| 秀山| 镶黄旗| 北碚区| 米泉市| 信丰县| 滦南县| 且末县| 金湖县| 八宿县| 鄂尔多斯市|