天天看點

XML DOM 擷取節點值

nodeValue 屬性用于擷取節點的文本值。

getAttribute() 方法傳回屬性的值。

在 DOM 中,每種成分都是節點。元素節點沒有文本值。

元素節點的文本存儲在子節點中。該節點稱為文本節點。

擷取元素文本的方法,就是擷取這個子節點(文本節點)的值。

getElementsByTagName() 方法傳回包含擁有指定标簽名的所有元素的節點清單,其中的元素的順序是它們在源文檔中出現的順序。

下面的代碼通過使用 loadXMLDoc() 把 books.xml 載入 xmlDoc 中并檢索第一個 <title> 元素:

xmlDoc=loadXMLDoc("books.xml");

x=xmlDoc.getElementsByTagName("title")[0];

childNodes 屬性傳回子節點的清單。<title> 元素隻有一個子節點。它是一個文本節點。

下面的代碼檢索 <title> 元素的文本節點:

y=x.childNodes[0];

nodeValue 屬性傳回文本節點的文本值:

txt=y.nodeValue;

結果:txt = "Everyday Italian"

周遊所有 <title> 元素:

嘗試一下

在 DOM 中,屬性也是節點。與元素節點不同,屬性節點擁有文本值。

擷取屬性的值的方法,就是擷取它的文本值。

可以通過使用 getAttribute() 方法或屬性節點的 nodeValue 屬性來完成這個任務。

getAttribute() 方法傳回屬性<b>值</b>。

下面的代碼檢索第一個 &lt;title&gt; 元素的 "lang" 屬性的文本值:

txt=xmlDoc.getElementsByTagName("title")[0].getAttribute("lang");

結果:txt = "en"

執行個體解釋:

使用 loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中

把 txt 變量設定為第一個 title 元素節點的 "lang" 屬性的值

周遊所有的 &lt;book&gt; 元素,并擷取它們的 "category" 屬性:

getAttributeNode() 方法傳回屬性<b>節點</b>。

下面代碼檢索第一個 &lt;title&gt; 元素的 "lang" 屬性的文本值:

x=xmlDoc.getElementsByTagName("title")[0].getAttributeNode("lang");

txt=x.nodeValue;

結果:Result: txt = "en"

擷取第一個 &lt;title&gt; 元素節點的 "lang" 屬性節點

把 txt 變量設定為屬性的值

周遊所有的 &lt;book&gt; 元素并擷取它們的 "category" 屬性: