首頁 >web前端 >html教學 >html中如何動態新增表格的實例分析

html中如何動態新增表格的實例分析

黄舟
黄舟原創
2018-05-11 17:11:416239瀏覽

這篇文章主要介紹了HTML中表格動態新增的實例程式碼,需要的朋友參考下吧

廢話不多說了,直接給大家貼程式碼了,具體程式碼如下圖:

<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=&#39;firstName&#39;/></td><td><input name=&#39;lastName&#39;/></td><td><input type=&#39;button&#39; value=&#39;Add&#39; onclick=&#39;add()&#39;> <input type=&#39;button&#39; value=&#39;Del&#39; onclick=&#39;del(this)&#39;></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=&#39;firstName&#39;/></td><td><input name=&#39;lastName&#39;/></td><td><input type=&#39;button&#39; value=&#39;Add&#39; onclick=&#39;add()&#39;> <input type=&#39;button&#39; value=&#39;Del&#39; onclick=&#39;del(this)&#39;></td>";  
        document.getElementById("tb").appendChild(trObj);  
    }

第一行,建立tr元素,即建立一個表格行。

第二行,trObj.id = new Date().getTime(); 給改行加上id 屬性,並給屬性賦值,取目前系統的毫秒數,這個主要是刪除的時候需要。

第三行,trObj.innerHTML = "b6c5a531a458a2e790c1fd6421739d1cfc0776cc3231ff86ed477176298b2f6ab90dd5946f0946207856a8a37f441edfb6c5a531a458a2e790c1fd6421739d1c6db34cf72169902e1f75009e71a863ddb90dd5946f0946207856a8a37f441edfb6c5a531a458a2e790c1fd6421739d1cf8d6ad27d1726ca1bb5bdfb6943a2de8

42774d28026b59fb3a4e4c8037f7bc83b90dd5946f0946207856a8a37f441edf"; 給表格行賦值,透過innerHTMML屬性,設定a34de1251f0d9fe1e645927f19a896e8標籤和fd273fcf5bcad3dfdad3c41bd81ad3e5標籤間的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所在的3a51f7a23cedd4d0ea1dfd9aced9538f域。

第一行,var trId = obj.parentNode.parentNode.id; 取得目前元素的父節點的父節點的id,也就是要刪除的行的id 。

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

第三行,document.getElementById("tb").removeChild(trObj); 在表格主體中刪除該行。

瑕疵

上面的程式碼基本上實作了動態為表格增加行和刪除行的功能,但是程式碼還有瑕疵,主要有這麼兩點:

1  表格在增加行前和增加行後,表格寬度改變

#增加行前

##增加行後

增加行後,表格列變寬了

2  瀏覽器預設開啟的頁面中文出現亂碼

需要設定字元編碼修改頁面編碼格式後才能正常顯示

以上是html中如何動態新增表格的實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn