问答详情
源自:9-22 编程练习

无法删除节点

点击删除 控制台报错Cannot read property 'parentNode' of undefined at del

代码如下

<script type="text/javascript">

window.onload = function() {

var tr = document.getElementsByTagName("tr");

for (var i = 0; i < tr.length; i++) {

tr[i].onmouseover = function() {

this.style.backgroundColor = '#f2f2f2';

}

tr[i].onmouseout = function() {

this.style.backgroundColor = '#fff';

}

}

} //1. 鼠标移到不同行上时背景色改为色值为 #f2f2f2,移开鼠标时则恢复为原背景色 #fff

var num = 2;

function add() {

num++;

var tr = document.createElement("tr");

var xh = document.createElement("td");

var xm = document.createElement("td");

var del = document.createElement("td");

xh.innerHTML = "xh00" + num;

xm.innerHTML = "<input value='请输入姓名'/>"; //?

del.innerHTML = "<a href='javascript:del(this)'>删除</a>";

var table = document.getElementById("table");

table.appendChild(tr);

tr.appendChild(xh);

tr.appendChild(xm);

tr.appendChild(del);

//插入节点

var tr = document.getElementsByTagName("tr");

for (var i = 0; i < tr.length; i++) {

tr[i].onmouseover = function() {

this.style.backgroundColor = '#f2f2f2';

}

tr[i].onmouseout = function() {

this.style.backgroundColor = '#fff';

}

}

}

function del(obj){

            var table = obj.parentNode.parentNode.parentNode;

var tr = obj.parentNode.parentNode;

table.removeChild(tr);

        }

</script>

调用函数用的<a href="javascript:del(this);">删除</a>

我的理解是 obj是a标签 obj.parentNode是td

 obj.parentNode.parentNode是tr

obj.parentNode.parentNode.parentNode是table

要删除table中的tr就是table.removeChild(tr);

提问者:luochyi 2020-03-21 10:56

个回答

  • Coooooolfznk
    2020-03-23 11:50:36

    我运行的结果是正确的,可能你函数调用那里有问题,这个函数应该没问题。

    http://img.mukewang.com/5e7831d60001418804790099.jpg

    http://img1.mukewang.com/5e7831ee0001c64003120151.jpg

    http://img.mukewang.com/5e7831f700011fc203240139.jpg删除了xh003