当前位置: 首页 > 网络学院 > XML相关教程 > XML DOM > firstChild 属性
The firstChild property returns the first child node of the selected element
firstChild属性的作用是:返回已选节点中的第一个子节点。
If the selected node has no children, this property returns NULL.
如果选定的节点部包含子节点,那么这个属性将返回NULL[空值]。
elementNode.firstChild |
Note: Internet Explorer will skip white-space text nodes that are generated between nodes (e.g. new-line characters), while Mozilla will not. So, in the example below, we have a function that checks the node type of the first child node.
注意:IE将跳过在节点之间产生的空格文档节点(如:换行字符),而Mozilla不会这样。在下面的案例中,我们将书写一个用于检测第一个子节点的节点类型的函数。
Element nodes has a nodeType of 1, so if the first child node is not an element node, it moves to the next node, and checks if this node is an element node. This continues until the first child node (which must be an element node) is found. This way, the result will be correct in both Internet Explorer and Mozilla.
元素节点包含的节点类行为1,因此,如果第一个节点不是元素节点,那么它将自动移动到下一个节点并检测该节点是否是一个元素节点;这样的过程将一直持续下去直到发现的第一个子节点是元素节点为止。通过使用这个方法,在IE浏览器或Mozilla浏览器中显示的结果就会同时正确。
Tip: To read more about the XML DOM differences between IE and Mozilla browsers, visit our Mozilla vs. IE chapter.
提示:如果你想获取更多关于XML DOM在IE和Mozilla浏览器中的不同,那你可以访问“Mozilla vs. IE ”这章。
In all examples, we will use the XML file books.xml, and the JavaScript function loadXMLDoc().
在所有案例中,我们将使用“book.xml”文件以及JavaScript 函数“loadXMLDoc()”。
The following code fragment gets the first child node from "books.xml":
下面的代码片断将获取“books.xml”文件中的第一个子节点:
//check if the first node is an element node function get_firstchild(n) { var x=n.firstChild; while (x.nodeType!=1) { x=x.nextSibling; } return x; } xmlDoc=loadXMLDoc("books.xml"); var x=xmlDoc.documentElement; var firstNode=get_firstchild(x); for (var i=0;i<firstNode.childNodes.length;i++) { if (firstNode.childNodes[i].nodeType==1) { //Process only element nodes document.write(firstNode.childNodes[i].nodeName); document.write(" = "); document.write(firstNode.childNodes[i].childNodes[0].nodeValue); document.write("<br />"); } } |
The output of the code above will be:
上述代码将输出下面的结果:
title = Everyday Italian author = Giada De Laurentiis year = 2005 price = 30.00 |
firstChild - Get the first child node in an XML document
firstChild - 获取XML文档中的第一个子节点