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>。
下面的代碼檢索第一個 <title> 元素的 "lang" 屬性的文本值:
txt=xmlDoc.getElementsByTagName("title")[0].getAttribute("lang");
結果:txt = "en"
執行個體解釋:
使用 loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中
把 txt 變量設定為第一個 title 元素節點的 "lang" 屬性的值
周遊所有的 <book> 元素,并擷取它們的 "category" 屬性:
getAttributeNode() 方法傳回屬性<b>節點</b>。
下面代碼檢索第一個 <title> 元素的 "lang" 屬性的文本值:
x=xmlDoc.getElementsByTagName("title")[0].getAttributeNode("lang");
txt=x.nodeValue;
結果:Result: txt = "en"
擷取第一個 <title> 元素節點的 "lang" 屬性節點
把 txt 變量設定為屬性的值
周遊所有的 <book> 元素并擷取它們的 "category" 屬性: