如何在相应行的按钮上删除表格行?

时间:2012-01-26 13:20:33

标签: javascript

这是我的代码:     

    function deleteHostTable(src) {
        var table = src.parentNode.parentNode.parentNode;
        if(table.rows.length > 1) {             
            table.deleteRow(src.parentNode.parentNode);
        }
         }
    function addHost(src) {
         var table = src.parentNode.parentNode.parentNode;
        var newRow = table.insertRow(table.rows.length-1);

        var cell = newRow.insertCell(newRow.cells.length);

        cell.innerHTML = '<input type="hidden" name = "vtierIdH" value = "vtierId" />'

        cell = newRow.insertCell(newRow.cells.length);
        cell.innerHTML = '<img src="images/minus.gif" onclick="deleteHostTable(this);return false;"/>';

        cell = newRow.insertCell(newRow.cells.length);
        cell.className = "pagetitle";
        cell.innerHTML = '<input type = "text" value="hstst" />';
    }
</script>
<html>
<table id="host#1" index="1">
        <tr>
            <td colspan="10">
            <h2 align="left" class="pagetitle">Sub Account Hosts:</h2>
            </td>
        </tr>
        <tr>
            <input type="hidden" name="vtierIdH" value="<%=vtierId %>" />

            <td><button id="minus" onclick="deleteHostTable(this);"/></td>
            <td class="pagetitle"><input type="text" value="hstst" /></td>
        </tr>
        <tr>
            <td><button  onclick="addHost(this);"></td>
        </tr>
    </table>
</html>

现在,当我单击与按钮对应的按钮时,此代码将删除最上面的行 而不是与单击该按钮对应的行。如何删除该行中按钮对应的行?

2 个答案:

答案 0 :(得分:2)

只需将删除功能更改为

即可
function deleteHostTable(src) {
    var row = src.parentNode.parentNode;
    row.parentNode.removeChild(row);
}

它不使用deleteRow的原因是它希望在传递对象时传递行的索引。

答案 1 :(得分:1)

您必须将“index”传递给table.deleteRow函数,而不是元素。

function deleteHostTable(src) {

    var table = src.parentNode.parentNode.parentNode;
    var row = src.parentNode.parentNode;
    for(var i = table.rows.length; i--; )
    {
        if ( table.rows[i] == row )
        {
            table.deleteRow(i);
            return;
        }
    }

}

此功能应该有效。

您也可以使用src.parentNode.parentNode.parentNode.removeChild(src.parentNode.parentNode)