当使用标准JavaScript删除一个元素时,你必须先去它的父元素:
var element = document.getElementById("element-id");
element.parentNode.removeChild(element);
必须先访问父节点对我来说似乎有点奇怪,这是JavaScript这样工作的原因吗?
当使用标准JavaScript删除一个元素时,你必须先去它的父元素:
var element = document.getElementById("element-id");
element.parentNode.removeChild(element);
必须先访问父节点对我来说似乎有点奇怪,这是JavaScript这样工作的原因吗?
当前回答
必须先访问父节点对我来说似乎有点奇怪,这是JavaScript这样工作的原因吗?
函数名是removeChild(),当没有父对象时如何可能删除子对象?:)
另一方面,您不必总是像您所显示的那样调用它。元素。parentNode只是一个获取给定节点的父节点的助手。如果你已经知道父节点,你可以像这样使用它:
Ex:
// 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
= = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =
补充一些东西:
一些回答指出,可以使用element .remove();而不是使用parentnode . removecchild (child);。但正如我所注意到的,这两个功能之间有区别,在那些答案中没有提到。
如果使用removeChild(),它将返回对已删除节点的引用。
var removedChild = element.parentNode.removeChild(element);
console.log(removedChild); //will print the removed child.
但是如果你使用element .remove();,它不会返回给你引用。
var el = document.getElementById('Example');
var removedChild = el.remove(); //undefined
https://developer.mozilla.org/en-US/docs/Web/API/ChildNode/remove
这种行为可以在Chrome和FF中观察到。我相信这值得注意:)
希望我的回答能对这个问题有所帮助!!
其他回答
// 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);
}
必须先访问父节点对我来说似乎有点奇怪,是吗 JavaScript这样工作的原因是什么?
恕我直言:这种情况的原因与我在其他环境中看到的是一样的:你正在执行一个基于你的“链接”的操作。当你链接到它时,你不能删除它。
就像砍树枝一样。砍树的时候要坐在离树最近的一边,否则结果会……不幸(尽管有趣)。
你可以使用element。remove()
使用ele. parentnode . removechild (ele)的函数不适用于已创建但尚未插入HTML的元素。jQuery和Prototype等库明智地使用如下方法来规避这种限制。
_limbo = document.createElement('div');
function deleteElement(ele){
_limbo.appendChild(ele);
_limbo.removeChild(ele);
}
我认为JavaScript是这样工作的,因为DOM最初的设计者把父/子导航和上/下导航作为比现在流行的DHTML修改更高的优先级。在90年代中期,能够读取一个<input type='text'>,并通过DOM中的相对位置写入另一个<input type='text'>是很有用的,当时整个HTML表单或交互式GUI元素的动态生成在一些开发人员眼中几乎是不存在的。
ChildNode.remove()方法将对象从它所属的树中移除。
https://developer.mozilla.org/en-US/docs/Web/API/ChildNode/remove
下面是一个演示如何调用document.getElementById('my-id').remove()的示例。
https://jsfiddle.net/52kp584L/
**
不需要扩展NodeList。它已经实施了。
**