Node.childNodes - Web APIs 编辑
The Node.childNodes
read-only property returns a live NodeList
of child nodes
of the given element where the first child node is assigned index 0. Child nodes include elements, text and comments.
Syntax
let nodeList = elementNodeReference.childNodes;
Examples
Simple usage
// parg is an object reference to a <p> element
// First check that the element has child nodes
if (parg.hasChildNodes()) {
let children = parg.childNodes;
for (let i = 0; i < children.length; i++) {
// do something with each child as children[i]
// NOTE: List is live! Adding or removing children will change the list's `length`
}
}
Remove all children from a node
// This is one way to remove all children from a node
// box is an object reference to an element
while (box.firstChild) {
//The list is LIVE so it will re-index each call
box.removeChild(box.firstChild);
}
Notes
The items in the collection of nodes are objects, not strings. To get data from node objects, use their properties. (For example, to get the name of the first childNode: elementNodeReference.childNodes[0].nodeName
.)
The document
object itself has 2 children: the Doctype declaration and the root element, typically referred to as documentElement
. (In (X)HTML documents this is the HTML
element.)
childNodes
includes all child nodes—including non-element nodes like text and comment nodes. To get a collection of only elements, use ParentNode.children
instead.
Specifications
Specification | Status | Comment |
---|---|---|
DOM The definition of 'Node.childNodes' in that specification. | Living Standard | No change |
Document Object Model (DOM) Level 3 Core Specification The definition of 'Node.childNodes' in that specification. | Obsolete | No change |
Document Object Model (DOM) Level 2 Core Specification The definition of 'Node.childNodes' in that specification. | Obsolete | No change |
Document Object Model (DOM) Level 1 Specification The definition of 'Node.childNodes' in that specification. | Obsolete | Initial definition |
Browser compatibility
BCD tables only load in the browser
See also
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论