首頁 >web前端 >js教程 >javascript中table怎麼刪除行

javascript中table怎麼刪除行

藏色散人
藏色散人原創
2021-07-01 10:14:293273瀏覽

javascript中table刪除行的實作方法:先建立一個HTML範例檔;然後定義一個table表格;最後透過「function deleteRow(_this){...}」方法實作刪除行的功能即可。

javascript中table怎麼刪除行

本文操作環境:windows7系統、javascript1.8.5版,DELL G3電腦

javascript中table怎麼刪除行?

JavaScript為table動態新增、刪除行

我一共寫了三種方法來實現新增行的功能,寫了一種方法來實現刪除行的功能,主要感覺是一定要熟悉JavaScript的API,其實這些東西API文件裡面都有,就看你是否知道JavaScript中有這個函數或屬性,然後把這些屬性和函數整合起來就是你想要的東西。

所有HTML元素都能用的常用函數:node.appendChild(node)、

所有HTML元素都能使用的常用屬性:element.tagName

document對象的常用方法:document.createElement(name)

43c4707103c6cc3650c2aeb71d2b1e8d中的常用函數:tableObject.insertRow(index)、tableObject.deleteRow(index)

43c4707103c6cc3650c2aeb71d2b1e8d中的常用屬性:tableObject.rows、tableObject.rows.length

7000aaa9af6133c37354a0015cd35a33中的常用函數:tablerowObject.insertCell(index)

868c3f8d39a371013a78a87c30e1b0d8中的常用屬性:tablerowObject .rowIndex

<style type="text/css">
    table{
        border:1px solid #000;
        border-collapse: collapse;
    }
    th,td{
        border:1px solid #000;
        padding:6px;
    }
</style>
<script type="text/javascript">
    function addRow1(){
        var userInfo = document.getElementById("userInfo");
        var row = document.createElement("tr");
        var td1 = document.createElement("td");
        td1.innerHTML = "李四";
        var td2 = document.createElement("td");
        td2.innerHTML = "102";
        var td3 = document.createElement("td");
        td3.innerHTML = "北海";
        var td4 = document.createElement("td");
        td4.innerHTML = "<a onclick=&#39;delete(this)&#39;>删除</a>";
        row.appendChild(td1);
        row.appendChild(td2);
        row.appendChild(td3);
        row.appendChild(td4);
        userInfo.appendChild(row);              
    }
    function addRow2(){
        var userInfo = document.getElementById("userInfo");
        var rowLength = userInfo.rows.length;
        //新行将被插入index所在行之前。若index等于表中的行数,则新行将被附加到表的末尾。
        //返回一个TableRow,表示新插入的行。
        var tableRow = userInfo.insertRow(rowLength);
        tableRow.innerHTML = "<td>李四</td><td>102</td><td>四海</td><td><a onclick=&#39;deleteRow(this)&#39;>删除</a></td>";
    }
    function addRow3(){
        var userInfo = document.getElementById("userInfo");
        //计算rows.length时会把表头包含在内
        var rowLength = userInfo.rows.length;
        var tableRow = userInfo.insertRow(rowLength);
        //新单元格将被插入当前位于 index 指定位置的表元之前
        //如果 index 等于行中的单元格数,则新单元格被附加在行的末尾。
        var tableCell0 = tableRow.insertCell(0);
        var tableCell1 = tableRow.insertCell(1);
        var tableCell2 = tableRow.insertCell(2);
        var tableCell3 = tableRow.insertCell(3);
        tableCell0.innerHTML = "李四";
        tableCell1.innerHTML = "103";
        tableCell2.innerHTML = "黑海";
        tableCell3.innerHTML = "<a onclick=&#39;deleteRow(this)&#39;>删除</a>";
    }
    //不能传初始化时当前元素所在行的rowIndex,因为删除操作之后当前元素所在行的rowIndex会发送变化
    function deleteRow(_this){
        var userInfo = document.getElementById("userInfo");
        var rowIndex = getTrIndex(_this);
        //deleteRow() 方法用于从表格删除指定位置的行
        //参数 index 指定了要删除的行在表中的位置
        userInfo.deleteRow(rowIndex);
    }
    function getTrIndex(element){
        if(element.tagName.toLowerCase() == "tr"){
            //rowIndex属性返回某一行在表格的行集合中的位置(row index)
            return element.rowIndex;
        }else{
            return getTrIndex(element.parentNode);
        }
    }
</script>

推薦學習:《javascript高階教學

以上是javascript中table怎麼刪除行的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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