您可以通过三种方式来访问节点:
1. 通过使用 getElementsByTagName() 方法。
2. 通过循环(遍历)节点树。
3. 通过利用节点的关系在节点树中导航。
getElementsByTagName() 返回拥有指定标签名的所有元素。
node.getElementsByTagName("tagname"); |
实例
下面的实例返回 x 元素下的所有 <title> 元素:
x.getElementsByTagName("title"); |
xmlDoc.getElementsByTagName("title"); |
getElementsByTagName() 方法返回节点列表。节点列表是节点的数组。
下面的代码使用 loadXMLDoc() 把 "books.xml" 载入 xmlDoc 中,然后在变量 x 中存储 <title> 节点的一个列表:
xmlDoc=loadXMLDoc("books.xml"); |
x=xmlDoc.getElementsByTagName("title"); |
y=x[2]; |
在本教程后面的章节中,您将学习更多有关节点列表(Node List)的知识。
length 属性定义节点列表的长度(即节点的数量)。
您可以通过使用 length 属性来遍历节点列表:
xmlDoc=loadXMLDoc("books.xml"); |
x=xmlDoc.getElementsByTagName("title"); |
for (i=0;i<x.length;i++) |
{ |
document.write(x[i].childNodes[0].nodeValue); |
document.write(" |
"); |
} |
XML 文档的 documentElement 属性是根节点。
节点的 nodeName 属性是节点的名称。
节点的 nodeType 属性是节点的类型。
您将在本教程的下一章中学习更多有关节点属性的知识。
下面的代码遍历根节点的子节点,同时也是元素节点:
xmlDoc=loadXMLDoc("books.xml"); |
x=xmlDoc.documentElement.childNodes; |
for (i=0;i<x.length;i++) |
{ |
if (x[i].nodeType==1) |
{//Process only element nodes (type 1) |
document.write(x[i].nodeName); |
document.write(" |
"); |
} |
} |
实例解释:
下面的代码使用节点关系导航节点树:
xmlDoc=loadXMLDoc("books.xml"); |
x=xmlDoc.getElementsByTagName("book")[0].childNodes; |
y=xmlDoc.getElementsByTagName("book")[0].firstChild; |
for (i=0;i<x.length;i++) |
{ |
if (y.nodeType==1) |
{//Process only element nodes (type 1) |
document.write(y.nodeName + " |
"); |
} |
y=y.nextSibling; |
} |