按ID删除元素

Zaz*_*Zaz 1085 javascript

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

var element = document.getElementById("element-id");
element.parentNode.removeChild(element);
Run Code Online (Sandbox Code Playgroud)

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

Joh*_*mar 623

我知道增加原生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]);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

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

document.getElementById("my-element").remove();
Run Code Online (Sandbox Code Playgroud)

要么

document.getElementsByClassName("my-elements").remove();
Run Code Online (Sandbox Code Playgroud)

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

  • 不应该是[document.getElementsByClassName("my-elements")[0] .remove(); 我认为函数remove()不是由数组实现的.为了删除类的所有元素或返回数组的任何选择器,您必须遍历所有元素并在每个元素上调用remove(). (3认同)
  • @slicedtoad你是对的,我的坏.我修改了函数以循环向后遍历元素.似乎工作正常.您所谈论的行为很可能是由更新的索引引起的. (2认同)

小智 270

Crossbrowser和IE> = 11:

document.getElementById("element-id").outerHTML = "";
Run Code Online (Sandbox Code Playgroud)

  • 这似乎是最简单,最可靠,最快速的解决方案.我不需要删除该元素,所以我跳过最后一行,但不应该添加任何开销.*注意*:我发现这一点,同时试图找到一个比`$ .ready` js更快的替代品`noscript`标签.为了按照我想要的方式使用它,我必须将其包装在1ms的"setTimeout"函数中.这一次解决了我所有的问题.格拉西亚斯. (3认同)
  • 这比 `removeChild` 慢一点(在我的系统上大约是 6-7%)。见 https://jsperf.com/clear-outerhtml-v-removechild/2 (2认同)

xsz*_*nix 157

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

function removeElement(id) {
    var elem = document.getElementById(id);
    return elem.parentNode.removeChild(elem);
}
Run Code Online (Sandbox Code Playgroud)

  • 如果你想要单线程而不是全局,你可以将`elem`改为`remove.elem`.这样函数引用自身,因此您不必创建另一个全局变量.:-) (12认同)
  • 所以,你为什么需要归还这个元素?为什么不``function remove(id){document.getElementById(id).parentNote.removeChild(document.getElementById(id)); }` (4认同)
  • @ZachL:虽然你的解决方案可能看起来更明显,但它执行两次DOM查找,这种查找速度较慢,而其他解决方案似乎想要避免这种情况. (4认同)
  • 不行.错误太多了.这有效:var elem = document.getElementById('id'); elem.parentNode.removeChild(ELEM); (3认同)
  • 哇,为什么这么复杂.只需将元素本身传递给函数而不是id字符串.这样,在整个功能中可以访问该元素,并且它保持一个衬里 (2认同)
  • @DavidFariñawhale,如果你想用这种方法删除一个元素,那么你将保留对已删除的dom元素的引用.我不太确定在具有自己的范围的for循环中会出现什么样的情况,但我认为你的方法可能会导致内存泄漏(因为你可能会维护对已删除元素的引用,因此它们不会被垃圾回收).我不是百分之百肯定的.虽然您的方法很好,只要您了解不需要在全局或大范围或跨功能中维护引用,它就会变得混乱. (2认同)

小智 98

这是DOM支持的内容.搜索该页面以"删除"或"删除",removeChild是唯一删除节点的页面.

  • 这回答了我原来的问题,但为什么JavaScript会像这样工作呢? (13认同)
  • 我只是在这里猜测,但我认为它与内存管理有关.父节点很可能拥有指向子节点的指针列表.如果您刚刚删除了一个节点(不使用父节点),则父节点仍将保持指针并导致内存泄漏.因此api强制您调用父项上的函数来删除子项.这也很好,因为它可以通过子节点向下走,在每个子节点上调用remove,而不是泄漏内存. (5认同)
  • 嘿伙计们,即使那个参考文献没有这个,我偶然发现了它.写`element.remove();`会起作用.也许这是新事物.但第一次对我来说它有效.我认为它应该一直有效,因为它必须有非常基本的东西. (2认同)

Zaz*_*Zaz 79

DOM在节点树中组织,其中每个节点都有一个值,以及对其子节点的引用列表.因此,element.parentNode.removeChild(element)模仿内部发生的事情:首先,您转到父节点,然后删除对子节点的引用.

从DOM4开始,提供了一个辅助函数来做同样的事情:element.remove().这适用于87%的浏览器(截至2016年),但不适用于IE 11.如果您需要支持旧版浏览器,您可以:

  • 请不要_“修改原生 DOM 函数”_。 (5认同)

csj*_*ter 35

删除一个元素:

 var elem = document.getElementById("yourid");
 elem.parentElement.removeChild(elem);
Run Code Online (Sandbox Code Playgroud)

要删除所有元素,例如某个类名:

 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]);
Run Code Online (Sandbox Code Playgroud)

  • +1用于按类名删除的简单示例.其他答案并未涵盖这一点 (4认同)

Sai*_*der 20

你可以使用 element.remove()

  • 在FireFox和Chrome上正常运行.谁在乎IE? (24认同)
  • `element.remove()`不是有效的JavaScript,仅适用于某些浏览器,例如[Chrome](http://stackoverflow.com/q/16151295). (13认同)
  • 有工作的人关心IE! (13认同)
  • 我的不好,[`element.remove()`*是带有DOM4的有效JavaScript](http://dom.spec.whatwg.org/#childnode),适用于所有现代浏览器,当然除了Internet Explorer . (10认同)
  • Josh,这是有效的javascript,只有Firefox和Chrome实现了它(参见MDN) (4认同)
  • 一些有工作的人关心IE (2认同)

Cod*_*ker 17

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

这是一个例子:

let subsWrapper = document.getElementById("element_id");
subsWrapper.remove();
//OR directly.
document.getElementById("element_id").remove();
Run Code Online (Sandbox Code Playgroud)


Ale*_*edt 16

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

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

这是一个小提琴,展示了你如何打电话 document.getElementById('my-id').remove()

https://jsfiddle.net/52kp584L/

**

无需扩展NodeList.它已经实施.

**

  • 注意,任何版本的IE都不支持此功能! (2认同)
  • 如果你还在为 IE 开发,我为你感到非常抱歉。 (2认同)

Nim*_*mal 7

首先必须去父节点对我来说有点奇怪,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);
Run Code Online (Sandbox Code Playgroud)

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.
Run Code Online (Sandbox Code Playgroud)

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

var el = document.getElementById('Example');
var removedChild = el.remove(); //undefined
Run Code Online (Sandbox Code Playgroud)

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

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

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


小智 6

使用ele.parentNode.removeChild(ele)的函数不适用于您已创建但尚未插入HTML的元素.像jQuery和Prototype这样的库明智地使用类似下面的方法来规避这种限制.

_limbo = document.createElement('div');
function deleteElement(ele){
    _limbo.appendChild(ele);
    _limbo.removeChild(ele);
}
Run Code Online (Sandbox Code Playgroud)

我认为JavaScript的工作方式与此类似,因为DOM的原始设计者将父/子和上一/下一导航作为比当今如此流行的DHTML修改更高的优先级.能够从一个<input type ='text'>读取并通过DOM中的相对位置写入另一个是有用的,在90年代中期,动态生成整个HTML表单或交互式GUI元素的时间几乎没有闪烁.一些开发人员的眼睛.


KHA*_*LFE 6

你可以简单地使用

document.getElementById("elementID").outerHTML="";
Run Code Online (Sandbox Code Playgroud)

它适用于所有浏览器,甚至适用于 Internet Explorer。


Red*_*Red 5

据DOM 4级规格,这是当前版本的发展,出现了一些新得心应手突变方法可供选择:append(),prepend(),before(),after(),replace(),和remove().

http://red-team-design.com/removing-an-element-with-plain-javascript-remove-method/


Kam*_*ski 5

最短的

我改进了Sai Sunder 的回答,因为 OP 使用 ID 可以避免 getElementById:

elementId.remove();
Run Code Online (Sandbox Code Playgroud)

elementId.remove();
Run Code Online (Sandbox Code Playgroud)
box2.remove();          // remove BOX 2

this["box-3"].remove(); // remove BOX 3 (for Id with 'minus' character)
Run Code Online (Sandbox Code Playgroud)