XML DOM childNodes 属性
定义和用法
childNodes 属性返回指定的节点的子节点的 NodeList。
提示:您可以使用 length 属性来确定子节点的数量,然后循环遍历所有子节点并提取您想要的信息。
语法
nodeObject.childNodes
技术细节
| 返回值: | 表示节点集合的 NodeList 对象。 |
|---|---|
| DOM 版本: | Core Level 1 |
实例
例子 1
下面的代码将 "books.xml" 加载到 xmlDoc 中,并显示 XML 文档的子节点:
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
myFunction(this);
}
};
xhttp.open("GET", "books.xml", true);
xhttp.send();
function myFunction(xml) {
var x, i, xmlDoc, txt;
xmlDoc = xml.responseXML;
txt = "";
x = xmlDoc.childNodes;
for (i = 0; i < x.length; i++) {
txt += "Nodename: " + x[i].nodeName +
" (nodetype: " + x[i].nodeType + ")";
}
document.getElementById("demo").innerHTML = txt;
}
例子 2
显示 XML 文档中所有元素的所有子节点:
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
if (this.readyState == 4 && this.status == 200) {
myFunction(this);
}
};
xhttp.open("GET", "books.xml", true);
xhttp.send();
function myFunction(xml) {
var x, y, i, xmlDoc, txt;
xmlDoc = xml.responseXML;
txt = "";
x = xmlDoc.documentElement;
y = x.childNodes;
for(i = 0; i < y.length; i++) {
txt += "Nodename: " + y[i].nodeName +
" (nodetype: " + y[i].nodeType + ")<br>";
for(z = 0; z < y[i].childNodes.length; z++) {
txt += "Nodename: " + y[i].childNodes[z].nodeName +
" (nodetype: " + y[i].childNodes[z].nodeType + ")<br>";
}
}
document.getElementById("demo").innerHTML =
"Nodename: " + xmlDoc.nodeName +
" (nodetype: " + xmlDoc.nodeType + ")<br>" +
"Nodename: " + x.nodeName +
" (nodetype: " + x.nodeType + ")<br>" +
txt;
}
浏览器支持
| Chrome | Edge | Firefox | Safari | Opera |
|---|---|---|---|---|
| Chrome | Edge | Firefox | Safari | Opera |
| 支持 | 支持 | 支持 | 支持 | 支持 |
所有主流浏览器都支持 childNodes 属性。