gpt4 book ai didi

javascript - 对父节点感到困惑

转载 作者:行者123 更新时间:2023-12-03 07:03:37 25 4
gpt4 key购买 nike

我对 JS 中的parentNode感到困惑。这是我的代码。

<table border="1" width="50%" id="table">
<tr>
<th>id</th>
<th>name</th>
<th>del</th>
</tr>

<tr>
<td>001</td>
<td>Kevin</td>
<td><a href="javascript:;" onclick="del(this);">del</a></td>
</tr>

和 JS 代码:

function del(obj){
var tr = obj.parentNode.parentNode;
tr.parentNode.removeChild(tr)
}

代码有效,我认为obj<a>标签,obj.parentNode<td>标签,obj.parentNode.parentNode<tbody>标签。所以tr.parentNode.removeChild(tr)意味着删除 <tr>标签。我说得对吗?

问题是,如果我像这样更改代码。它不起作用。

function del(obj){
var tr = obj.parentNode.parentNode.parentNode;
tr.removeChild(tr)
}

最佳答案

原因

tr.removeChild(tr)

不起作用是因为 tr 不是 tr 的子级,即它本身。但是,tr.parentNode.removeChild(tr) 可以工作,因为 tr 显然是 tr.parentNode 的子级。

关于javascript - 对父节点感到困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36920623/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com