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

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

必须先访问父节点对我来说似乎有点奇怪,这是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这样工作的原因吗?

函数名是removeChild(),当没有父对象时如何可能删除子对象?:)

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

Ex:

// 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/en-US/docs/Web/API/Node/removeChild

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

补充一些东西:

一些回答指出,可以使用element .remove();而不是使用parentnode . removecchild (child);。但正如我所注意到的,这两个功能之间有区别,在那些答案中没有提到。

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

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

但是如果你使用element .remove();,它不会返回给你引用。

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

https://developer.mozilla.org/en-US/docs/Web/API/ChildNode/remove

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

希望我的回答能对这个问题有所帮助!!

删除一个元素:

 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]);

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

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

ChildNode.remove()方法将对象从它所属的树中移除。

https://developer.mozilla.org/en-US/docs/Web/API/ChildNode/remove

下面是一个演示如何调用document.getElementById('my-id').remove()的示例。

https://jsfiddle.net/52kp584L/

**

不需要扩展NodeList。它已经实施了。

**