js移除html指定id元素,javascript - 按ID删除元素

javascript - 按ID删除元素

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

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

element.parentNode.removeChild(element);

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

Zaz asked 2018-12-22T19:29:53Z

16个解决方案

520 votes

我知道增加原生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();

要么

document.getElementsByClassName("my-elements").remove();

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

Johan Dettmar answered 2018-12-22T19:30:12Z

217 votes

跨浏览器和IE> = 11:

document.getElementById("element-id").outerHTML = "";

user2192293 answered 2018-12-22T19:30:32Z

136 votes

您可以制作remove功能,这样您就不必每次都考虑它:

function removeElement(id) {

var elem = document.getElementById(id);

return elem.parentNode.removeChild(elem);

}

xsznix answered 2018-12-22T19:30:52Z

93 votes

这是DOM支持的。 搜索该页面以“删除”或“删除”,removeChild是唯一删除节点的页面。

Christian Sirolli answered 2018-12-22T19:31:12Z

75 votes

DOM组织在节点树中,其中每个节点都有一个值,以及对其子节点的引用列表。 所以element.remove()模仿内部发生的事情:首先你去父节点,然后删除对子节点的引用。

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

通过父节点删除元素,如问题所示,

修改原生DOM功能,如Johan Dettmar的回答,或

使用DOM4 polyfill。

Zaz answered 2018-12-22T19:31:50Z

34 votes

删除一个元素:

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

csjpeter answered 2018-12-22T19:32:14Z

19 votes

你可以使用element.remove()

Sai Sunder answered 2018-12-22T19:32:34Z

14 votes

document.getElementById('my-id').remove()方法从其所属的树中删除对象。

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

这是一个小提琴,显示如何拨打document.getElementById('my-id').remove()

[https://jsfiddle.net/52kp584L/]

**

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

**

Alex Fallenstedt answered 2018-12-22T19:33:20Z

6 votes

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

_limbo = document.createElement('div');

function deleteElement(ele){

_limbo.appendChild(ele);

_limbo.removeChild(ele);

}

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

Psudo answered 2018-12-22T19:33:45Z

5 votes

根据DOM级别4规格(其是当前正在开发的版本),存在一些新的方便的突变方法:append(),prepend(),before(),after(),replace()和remove()。

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

Red answered 2018-12-22T19:34:10Z

4 votes

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

函数名称是elem.remove();,如果没有父项,如何删除子项?:)

另一方面,您并不总是如您所示那样调用它。 elem.remove();只是获取给定节点的父节点的辅助工具。 如果您已经知道父节点,则可以像这样使用它:

例如:

// 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]

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

要添加更多内容:

有些答案指出,不是使用elem.remove();,而是使用elem.remove();.但正如我所注意到的,这两个函数之间存在差异,并且在这些答案中没有提及。

如果您使用elem.remove();,它将返回对已删除节点的引用。

var removedChild = element.parentNode.removeChild(element);

console.log(removedChild); //will print the removed child.

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

var el = document.getElementById('Example');

var removedChild = el.remove(); //undefined

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

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

希望我的回答能为这个问题增添一些价值,并且会有所帮助!!

Nimeshka Srimal answered 2018-12-22T19:35:23Z

3 votes

首先要去父节点看起来有点奇怪,是吗   JavaScript的工作原理是什么?

恕我直言:其原因与我在其他环境中看到的相同:您正在根据您对某事的“链接”执行操作。 您链接到它时无法删除它。

喜欢砍树枝。 在切割时坐在离树最近的一侧,结果将是......不幸(尽管很有趣)。

TheSatinKnight answered 2018-12-22T19:35:53Z

2 votes

这个实际上来自FireFox ......一次,IE领先于包,并允许直接删除元素。

这只是我的假设,但我相信你必须通过父母移除一个孩子的原因是由于FireFox处理引用的方式存在问题。

如果你直接调用一个对象来提交hari-kari,那么在它死后立即你仍然持有它的引用。 这有可能产生几个令人讨厌的错误...例如无法删除它,删除它但保持对它的引用看似有效,或者只是内存泄漏。

我相信当他们意识到这个问题时,解决方法是通过其父元素删除元素,因为当元素消失时,您现在只是持有对父元素的引用。 这将阻止所有这些不愉快,并且(例如,如果按节点关闭一个树节点)将很好地“压缩”。

它应该是一个容易修复的错误,但与Web编程中的许多其他内容一样,发布可能很匆忙,导致这个...当下一个版本出现时,有足够的人使用它,改变这将导致 打破一堆代码。

再一次,所有这些只是我的猜测。

然而,我确实期待有一天网络编程最终得到一个完整的春季清洁,所有这些奇怪的小特性都被清理干净,每个人都开始按照相同的规则玩。

可能是在我的机器人仆人起诉我后退工资的第二天。

SilentThunderStorm answered 2018-12-22T19:36:45Z

0 votes

据我所知,直接删除节点在Firefox中不起作用,只能在Internet Explorer中起作用。 所以,为了支持Firefox,你必须去父母去除它的孩子。

参考:[http://chiragrdarji.wordpress.com/2007/03/16/removedelete-element-from-page-using-javascript-working-in-firefoxieopera/]

James answered 2018-12-22T19:37:09Z

0 votes

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

}

will Farrell answered 2018-12-22T19:37:25Z

-3 votes

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

function Remove(EId)

{

return(EObj=document.getElementById(EId))?EObj.parentNode.removeChild(EObj):false;

}

EId的注释。

这是一个等号不是EId。

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

Amin Atabakzadeh answered 2018-12-22T19:37:58Z

<think>首先,用户的问题是:“我想使用JavaScript删除具有指定IDHTML元素 请问JavaScript 删除 HTML 元素通过 ID”。这是一个关于使用JavaScript删除HTML元素的问题。 根据系统级指令: - 所有行内数学表达式必须使用 $...$ 格式,但这里没有数学表达式,所以不需要。 - 独立公式必须使用 $$...$$ 格式并单独成段,但这里没有公式。 - LaTeX语法正确:确保任何数学部分正确,但问题不涉及数学。 - 使用中文回答:整个回答要用中文。 - 生成相关问题:在回答结束后,添加相关问题部分。 - 回答中引用的段落末尾自然地添加引用标识:例如 [^1]。用户提供了引用,我需要引用它们。 用户提供的引用: - [^1]: 关于 innerText 属性。 - [^2]: 关于通过 id 取得元素- [^3]: 关于删除元素移除、querySelector、removeChild、remove。 - [^4]: 关于按 ID 删除元素。 用户的问题是关于删除具有指定ID元素,所以我需要整合这些引用。 关键点: -JavaScript 中,要删除一个元素,你需要先获取它。 - 获取元素可以通过 document.getElementById(id) 方法。 - 然后,使用 remove() 方法或 removeChild() 方法来删除它。 从引用中: - [^2] 提到通过 id 取得元素:使用 document.getElementById("id")。 - [^3] 提到使用 removeChild() 或 remove() 方法删除元素- [^4] 也提到按 ID 删除元素。 现代方法是使用 remove() 方法,它更简单。但为了兼容性,removeChild() 也常用。 回答结构: - 结构清晰,逐步解决问题。 - 解释步骤:1. 获取元素。2. 删除元素- 提供代码示例。 - 确保回答真实可靠。 步骤: 1. 获取元素:使用 document.getElementById("yourId"),其中 "yourId" 是元素ID。 2. 删除元素:调用该元素的 remove() 方法,或者使用父元素的 removeChild() 方法。 代码示例: - 使用 remove():element.remove(); - 使用 removeChild():parent.removeChild(element); 为了完整,解释一下。 添加引用: - 在相关段落末尾添加引用标识。 最后,生成相关问题。 完整回答: - 介绍问题。 - 逐步解释。 - 代码示例。 - 结尾。 相关问题: - 基于主题,生成 2-3 个相关问题。 生成相关问题: 1. 如何删除多个具有相同类名的元素? 2. 删除元素后如何恢复它? 3. 使用 JavaScript 删除元素有哪些替代方法? 等等。</think>### JavaScript 删除具有指定 IDHTML 元素JavaScript 中,删除具有指定 IDHTML 元素是一个常见操作。核心步骤包括:先通过 ID 获取元素对象,然后调用删除方法。我将逐步解释这个过程,确保代码简单易懂、兼容主流浏览器(如 Chrome、Firefox、Edge)。以下是详细步骤: #### 步骤 1: 获取元素对象 首先,你需要使用 `document.getElementById()` 方法获取指定 ID元素对象。这个方法返回一个元素节点,如果元素不存在,则返回 `null`。语法如下: ```javascript let element = document.getElementById("yourElementId"); // 替换 "yourElementId" 为实际 ID ``` - 例如,如果元素 ID 是 `myDiv`,则代码为:`let element = document.getElementById("myDiv");` - 这个方法直接从 DOM 中选择元素,效率高且可靠[^2]。 #### 步骤 2: 删除元素 获取元素后,有两种常用删除方法: - **推荐方法:使用 `remove()`** 这是现代浏览器(IE11+)支持的直接方法。调用元素的 `remove()` 方法会立即将其从 DOM 中移除: ```javascript if (element) { element.remove(); // 删除元素 } ``` 如果元素存在(`element` 不为 `null`),`remove()` 会删除元素及其所有子节点。代码简洁,无需查找父元素[^3]。 - **兼容方法:使用 `removeChild()`** 对于旧浏览器(如 IE10),可以使用父元素的 `removeChild()` 方法。这需要先获取元素的父节点: ```javascript if (element) { let parent = element.parentNode; // 获取父元素 parent.removeChild(element); // 通过父节点删除元素 } ``` `removeChild()` 返回被删除的节点,可以用于后续操作(如恢复元素)[^3][^4]。 #### 完整代码示例 以下是一个完整的 HTML 示例,展示如何通过按钮点击删除指定 ID元素: ```html <!DOCTYPE html> <html> <head> <title>删除元素示例</title> </head> <body> <div id="myDiv">这是一个将被删除元素</div> <button onclick="deleteElement()">删除元素</button> <script> function deleteElement() { // 步骤 1: 获取元素 let element = document.getElementById("myDiv"); // 步骤 2: 删除元素(使用 remove() 方法) if (element) { element.remove(); // 删除元素 console.log("元素删除"); } else { console.log("元素不存在"); } } </script> </body> </html> ``` - **说明**:点击按钮时,`deleteElement()` 函数会获取 ID 为 `myDiv` 的元素,并调用 `remove()` 删除它。如果元素不存在,控制台会输出警告。 - **注意事项**: - 确保 ID 在页面中唯一,否则 `getElementById()` 可能无法正确获取元素[^2]。 - 删除元素后,其内存会被浏览器自动回收,无需额外操作[^3]。 - 如果元素包含事件监听器,建议在删除移除它们以避免内存泄漏[^4]。 #### 常见问题解答 - **元素不存在怎么办?** 在代码中添加 `if (element)` 检查,避免错误(如 `Cannot read properties of null`)。 - **兼容性问题?** `remove()` 在 IE11 及以上支持。对于旧浏览器,使用 `removeChild()` 方法[^3][^4]。 - **性能影响?** 直接通过 ID 获取元素是高效的,时间复杂度为 $O(1)$,不会显著影响页面性能[^2]。 通过以上步骤,你可以轻松删除任何指定 IDHTML 元素。如果需要处理动态内容或复杂场景,请参考相关文档[^3][^4]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值