当使用标准JavaScript删除一个元素时,你必须先去它的父元素:
var element = document.getElementById("element-id");
element.parentNode.removeChild(element);
必须先访问父节点对我来说似乎有点奇怪,这是JavaScript这样工作的原因吗?
当使用标准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();
or
document.getElementsByClassName("my-elements").remove();
注意:此解决方案不适用于ie7及以下版本。有关扩展DOM的更多信息,请阅读本文。
编辑:回顾我在2019年的回答,node.remove()已经来拯救了,可以如下使用(没有上面的填充):
document.getElementById("my-element").remove();
or
[...document.getElementsByClassName("my-elements")].map(n => n && n.remove());
这些功能在所有现代浏览器(不是IE)中都可用。在MDN上阅读更多。
其他回答
据我所知,Firefox中不能直接删除节点,Internet Explorer中才可以。所以,要支持Firefox,你必须到父节点去移除它的子节点。
裁判:http://chiragrdarji.wordpress.com/2007/03/16/removedelete-element-from-page-using-javascript-working-in-firefoxieopera/
更新2011
这是在2011年添加到DOM规范中的,所以你可以使用:
element.remove()
DOM组织在一个节点树中,其中每个节点都有一个值,以及对其子节点的引用列表。因此,element. parentnode . removechild (element)准确地模拟了内部发生的情况:首先访问父节点,然后删除对子节点的引用。
从DOM4开始,提供了一个辅助函数来做同样的事情:element.remove()。这在96%的浏览器(截至2020年)中有效,但不包括IE 11。
如果你需要支持旧的浏览器,你可以:
通过父节点删除元素 修改本机DOM函数,如Johan Dettmar的回答,或者 使用DOM4填充材料。
这是在没有脚本错误的情况下删除元素的最佳函数:
function Remove(EId)
{
return(EObj=document.getElementById(EId))?EObj.parentNode.removeChild(EObj):false;
}
注意EObj=document.getElementById(EId)。
这是一个等号,不是==。
如果元素id存在,则函数将其删除,否则返回false,而不是error。
根据DOM级别4规范(目前正在开发的版本),有一些新的方便的突变方法可用:append()、prepend()、before()、after()、replace()和remove()。
https://catalin.red/removing-an-element-with-plain-javascript-remove-method/
您可以使用DOM的remove()方法直接删除该元素。
这里有一个例子:
let subsWrapper = document.getElementById("element_id");
subsWrapper.remove();
//OR directly.
document.getElementById("element_id").remove();