按 ID 删除元素

使用标准 JavaScript 删除元素时,必须首先转到其父元素:

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

首先必须去父节点对我来说有点奇怪,JavaScript 是否有这样的原因?

答案

我知道,增强本机 DOM 功能并不总是最好的或最受欢迎的解决方案,但是对于现代浏览器来说,这很好。

Element.prototype.remove = function() {
    this.parentElement.removeChild(this);
}
NodeList.prototype.remove = HTMLCollection.prototype.remove = function() {
    for(var i = this.length - 1; i >= 0; i--) {
        if(this[i] && this[i].parentElement) {
            this[i].parentElement.removeChild(this[i]);
        }
    }
}

然后您可以删除这样的元素

document.getElementById("my-element").remove();

要么

document.getElementsByClassName("my-elements").remove();

注意:此解决方案不适用于 IE 7 及更低版本。有关扩展 DOM 的更多信息,请阅读本文

编辑 :回顾我在 2019 年的答案, node.remove()可以解决问题,并且可以按以下方式使用(没有上面的 polyfill):

document.getElementById("my-element").remove();

要么

[...document.getElementsByClassName("my-elements")].map(n => n && n.remove());

这些功能在所有现代浏览器(不是 IE)中都可用。阅读有关MDN 的更多信息。

跨浏览器和 IE> = 11:

document.getElementById("element-id").outerHTML = "";

您可以创建一个remove函数,这样您就不必每次都考虑它:

function removeElement(id) {
    var elem = document.getElementById(id);
    return elem.parentNode.removeChild(elem);
}

这就是 DOM 支持的内容 。在该页面上搜索 “删除” 或 “删除”, removeChild是唯一删除节点的页面。

DOM 以节点树的形式组织,其中每个节点都有一个值,以及对其子节点的引用列表。因此element.parentNode.removeChild(element)精确地模拟了内部发生的情况:首先进入父节点,然后删除对子节点的引用。

从 DOM4 开始,提供了一个辅助函数来执行相同的操作: element.remove() 。此功能可在 87%的浏览器中使用 (截至 2016 年),但不适用于 IE11。如果需要支持旧版浏览器,则可以:

要删除一个元素:

var elem = document.getElementById("yourid");
 elem.parentElement.removeChild(elem);

为了删除所有具有特定类名的元素:

var list = document.getElementsByClassName("yourclassname");
 for(var i = list.length - 1; 0 <= i; i--)
 if(list[i] && list[i].parentElement)
 list[i].parentElement.removeChild(list[i]);

你可以只使用element.remove()

ChildNode.remove()方法从其所属的树中删除该对象。

https://developer.mozilla.org/zh-CN/docs/Web/API/ChildNode/remove

这是一个小提琴,显示了如何调用document.getElementById('my-id').remove()

https://jsfiddle.net/52kp584L/

**

无需扩展 NodeList。它已经被实施。

**

根据 DOM 4 规范(正在开发的最新版本),有一些可用的方便的新突变方法: append()prepend()before()after()replace()remove()

https://catalin.red/removing-an-element-with-plain-javascript-remove-method/

首先必须去父节点对我来说有点奇怪,JavaScript 是否有这样的原因?

函数名称为removeChild() ,在没有父项的情况下如何删除子项? :)

另一方面,您并不一定总是像显示的那样调用它。 element.parentNode只是获取给定节点的父节点的助手。如果您已经知道父节点,则可以像这样使用它:

例如:

// Removing a specified element when knowing its parent node
var d = document.getElementById("top");
var d_nested = document.getElementById("nested");
var throwawayNode = d.removeChild(d_nested);

https://developer.mozilla.org/zh-CN/docs/Web/API/Node/removeChild

================================================== =======

要添加更多内容:

一些答案指出,不要使用parentNode.removeChild(child); ,您可以使用elem.remove(); 。但是,正如我已经注意到的,这两个功能之间存在差异,并且在这些答案中并未提及。

如果使用removeChild() ,它将返回对已删除节点的引用。

var removedChild = element.parentNode.removeChild(element); 
console.log(removedChild); //will print the removed child.

但是,如果您使用elem.remove(); ,它不会返回您的参考。

var el = document.getElementById('Example');
var removedChild = el.remove(); //undefined

https://developer.mozilla.org/zh-CN/docs/Web/API/ChildNode/remove

在 Chrome 和 FF 中可以观察到此行为。我相信这是值得注意的:)

希望我的回答为问题增加一些价值,并会有所帮助!!