佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > HTML中表格動(dòng)態(tài)添加_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

HTML中表格動(dòng)態(tài)添加_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理

熱門標(biāo)簽:阿里云 網(wǎng)站建設(shè) 百度競(jìng)價(jià)點(diǎn)擊價(jià)格的計(jì)算公式 使用U盤裝系統(tǒng) 檢查注冊(cè)表項(xiàng) 硅谷的囚徒呼叫中心 美圖手機(jī) 智能手機(jī)

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

<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è)置字符編碼修改頁面編碼格式后才能正常顯示

標(biāo)簽:懷化 煙臺(tái) 黃山 賀州 湖北 湘潭 通遼 山南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML中表格動(dòng)態(tài)添加_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    信丰县| 章丘市| 正定县| 巴彦淖尔市| 台南县| 巧家县| 张家口市| 萨嘎县| 太保市| 芮城县| 名山县| 昌黎县| 梨树县| 罗田县| 苗栗市| 贞丰县| 锡林郭勒盟| 南岸区| 临夏市| 衢州市| 上高县| 惠安县| 岳普湖县| 万源市| 北海市| 商城县| 理塘县| 平邑县| 远安县| 合水县| 新余市| 邢台县| 祁门县| 大埔县| 长海县| 六枝特区| 夏河县| 瓦房店市| 乐安县| 肇州县| 元氏县|