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

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

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


当前回答

这是在没有脚本错误的情况下删除元素的最佳函数:

function Remove(EId)
{
    return(EObj=document.getElementById(EId))?EObj.parentNode.removeChild(EObj):false;
}

注意EObj=document.getElementById(EId)。

这是一个等号,不是==。

如果元素id存在,则函数将其删除,否则返回false,而不是error。

其他回答

// http://javascript.crockford.com/memory/leak.html
// cleans dom element to prevent memory leaks
function domPurge(d) {
    var a = d.attributes, i, l, n;
    if (a) {
        for (i = a.length - 1; i >= 0; i -= 1) {
            n = a[i].name;
            if (typeof d[n] === 'function') {
                d[n] = null;
            }
        }
    }
    a = d.childNodes;
    if (a) {
        l = a.length;
        for (i = 0; i < l; i += 1) {
            domPurge(d.childNodes[i]);
       }
    }
}

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

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

这里有一个例子:

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

更新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/