当使用标准JavaScript删除一个元素时,你必须先去它的父元素:

var element = document.getElementById("element-id");
element.parentNode.removeChild(element);

必须先访问父节点对我来说似乎有点奇怪,这是JavaScript这样工作的原因吗?


当前回答

必须先访问父节点对我来说似乎有点奇怪,是吗 JavaScript这样工作的原因是什么?

恕我直言:这种情况的原因与我在其他环境中看到的是一样的:你正在执行一个基于你的“链接”的操作。当你链接到它时,你不能删除它。

就像砍树枝一样。砍树的时候要坐在离树最近的一边,否则结果会……不幸(尽管有趣)。

其他回答

您可以使用DOM的remove()方法直接删除该元素。

这里有一个例子:

let subsWrapper = document.getElementById("element_id");
subsWrapper.remove();
//OR directly.
document.getElementById("element_id").remove();

据我所知,Firefox中不能直接删除节点,Internet Explorer中才可以。所以,要支持Firefox,你必须到父节点去移除它的子节点。

裁判:http://chiragrdarji.wordpress.com/2007/03/16/removedelete-element-from-page-using-javascript-working-in-firefoxieopera/

必须先访问父节点对我来说似乎有点奇怪,是吗 JavaScript这样工作的原因是什么?

恕我直言:这种情况的原因与我在其他环境中看到的是一样的:你正在执行一个基于你的“链接”的操作。当你链接到它时,你不能删除它。

就像砍树枝一样。砍树的时候要坐在离树最近的一边,否则结果会……不幸(尽管有趣)。

更新2011

这是在2011年添加到DOM规范中的,所以你可以使用:

element.remove()

DOM组织在一个节点树中,其中每个节点都有一个值,以及对其子节点的引用列表。因此,element. parentnode . removechild (element)准确地模拟了内部发生的情况:首先访问父节点,然后删除对子节点的引用。

从DOM4开始,提供了一个辅助函数来做同样的事情:element.remove()。这在96%的浏览器(截至2020年)中有效,但不包括IE 11。

如果你需要支持旧的浏览器,你可以:

通过父节点删除元素 修改本机DOM函数,如Johan Dettmar的回答,或者 使用DOM4填充材料。

你可以简单地使用

document.getElementById("elementID").outerHTML="";

它适用于所有浏览器,甚至是ie浏览器。