When removing an element with standard JavaScript, you must go to its parent first:
var element = document.getElementById("element-id");
element.parentNode.removeChild(element);
Having to go to the parent node first seems a bit odd to me, is there a reason JavaScript works like this?
This one actually comes from FireFox... for once, IE was ahead of the pack and allowed the removal of an element directly.
This is just my assumption, but I believe the reason that you must remove a child through the parent is due to an issue with the way FireFox handled the reference.
If you call an object to commit hari-kari directly, then immediately after it dies, you are still holding that reference to it. This has the potential to create several nasty bugs... such as failing to remove it, removing it but keeping references to it that appear valid, or simply a memory leak.
I believe that when they realized the issue, the work around was to remove an element through its parent because when the element is gone, you are now simply holding a reference to the parent. This would stop all that unpleasantness, and (if closing down a tree node by node, for example) would 'zip-up' rather nicely.
It should be an easily fixable bug, but as with many other things in web programming, the release was probably rushed, leading to this... and by the time the next version came around, enough people were using it that changing this would lead to breaking a bunch of code.
Again, all of this is simply my guesswork.
I do, however, look forward to the day when web programming finally gets a full spring cleaning, all these strange little idiosynchracies get cleaned up, and everyone starts playing by the same rules.
Probably the day after my robot servant sues me for back wages.
The DOM is organized in a tree of nodes, where each node has a value, along with a list of references to its child nodes. So
element.parentNode.removeChild(element)
mimics exactly what is happening internally: First you go the the parent node, then remove the reference to the child node.As of DOM4, a helper function is provided to do the same thing:
element.remove()
. This works in 87% of browsers (as of 2016), but not IE 11. If you need to support older browsers, you can:The
ChildNode.remove()
method removes the object from the tree it belongs to.https://developer.mozilla.org/en-US/docs/Web/API/ChildNode/remove
Here is a fiddle that shows how you can call
document.getElementById('my-id').remove()
https://jsfiddle.net/52kp584L/
**
There is no need to extend NodeList. It has been implemented already.
**
I know that augmenting native DOM functions isn't always the best or most popular solution, but this works fine for modern browsers.
And then you can remove elements like this
or
Note: this solution doesn't work for IE 7 and below. For more info about extending the DOM read this article.
Crossbrowser and IE >= 11: