2012-02-21 63 views
0

我已经在Javascript中动态添加/删除行,添加行时没有问题,只有在删除行时出现问题。 现在,我所做的是,当我想删除一行它总是删除最后一个,所以我认为I want if it only can be deleted the selected row,我不知道如何修改脚本到我想要的。如何删除Javascript中的一行?

下面是脚本:

var i=0; 
function addRow() 
{ 
i++; 
    m.r.value = i; 
    var tbl = document.getElementById('table'); 
    var lastRow = tbl.rows.length; 
    var iteration = lastRow - 1; 
    var row = tbl.insertRow(lastRow); 

    var cellLeft = row.insertCell(0); 
    var textNode = document.createTextNode(iteration); 
    cellLeft.appendChild(textNode); 

    var cellRightSel1 = row.insertCell(1); 
    var sel = document.createElement('select'); 
    sel.name = 'name' + iteration; 
    sel.setAttribute("onchange", "choosec(this);");  
    var item = new Option("",""); 
    sel.options[sel.length] = item; 
    <? 
    while($data = mysql_fetch_array($result)){          
    ?> 
    var item = new Option("<?=$data["Name"];?>","<?=$data["ID"];?>"); 
    sel.options[sel.length] = item; 
    <? } ?> 
    cellRightSel1.appendChild(sel); 

    var cellRightSel2 = row.insertCell(2); 
    var sel = document.createElement('select'); 
    sel.name = 'class' + iteration; 
    sel.setAttribute("onchange", "choosepoint(this);");  
    var item = new Option ("",""); 
    sel.options[sel.length] = item; 
    <? 
    while($data = mysql_fetch_array($result_sub)){          
    ?> 
    var item = new Option("<?=$data["Class"];?>","<?=$data["ID"];?>"); 
    sel.options[sel.length] = item; 
    <? } ?> 
    cellRightSel2.appendChild(sel); 

    var cellRight = row.insertCell(3); 
    var div = document.createElement('div'); 
    div.id = 'point' + iteration; 
    cellRight.appendChild(div); 
} 


function removeRow(){ 
    var tbl = document.getElementById('table'); 
    var lastRow = tbl.rows.length; 
    var rem = lastRow - 1; 
    if (lastRow > 2) tbl.deleteRow(rem); 
} 

帮助表示赞赏,感谢。

我的亟待解决的问题:

function removeRow(t){ 
     var i = t.parentNode.parentNode.rowIndex; 
     var tbl = document.getElementById('table'); 
     var lastRow = tbl.rows.length; 
     var iteration = lastRow - 1; 
     tbl.deleteRow(i); 
    } 
+0

一个名为'i'的全局变量?内联事件处理程序?你有没有考虑过使用jQuery? (其实,在像Raynos这样的人抱怨提示jQuery之前,你也可以在没有jQuery的情况下进行改进 - 但为什么要写更多的代码而不是encessary) – ThiefMaster 2012-02-21 16:16:48

回答

0

这是需要改变的代码:

var rem = lastRow - 1; 

眼下,这始终会是最后一排。你可以建立一些逻辑来传递索引,或者寻找一个字符串,或者其他任何东西,但是tbl.deleteRow()需要在特定索引处删除。

如果你想删除第3行,例如:

var rem = 2; //zero-based index 
3

尝试这样

<tr onclick="removeRow(this);">...</tr> 

然后在JavaScript方法

function removeRow(row){ 
    var tbl = row.parentNode; 
    var index = row.parentNode.rowIndex; 
    if (index > 2) tbl.deleteRow(index); 
} 

我找到了一个好例如适合您的要求。 check here

+0

谢谢Mr.rajkumar,我已经找到了问题:) – candies 2012-02-29 04:08:17

+0

欢迎你的朋友.. – 2012-02-29 05:10:37

+0

@candies我认为你应该标记这个答案是正确的。 – 2013-10-22 06:25:27