XML 取得元素的字符數據
列表9-3 中的script 程序使用每個子元素(TITLE、AUTHOR、BINDING、PAGES 與PRICE)的text 屬性,來作為取得元素字符數據的快捷方法。例如,下列的程序代碼被用來擷取TITLE元素中的字符數據:
title.innerText=Document.documentElement.childNodes(0).text;
text 屬性不僅提供了目前節點所代表的元素其文字內容,也提供任何后續元素的文字內容。當元素沒有任何子元素時,該屬性可以正確地擷取元素中的文字內容(如元素TITLE)。然而,如果元素包含一個以上的子元素與字符數據,則text 屬性將傳回所有的文字,如同下面范例所示(在這個范例中是「Moby-Dick Or,the Whale」)。
<TITLE>Moby-Dick
<SUBTITLE>Or,the Whale</SUBTITLE>
</TITLE>
為了只取得TITLE 元素的字符數據,你必須存取TITLE 元素的子文字節點。
表格9-1 中,Element 節點的nodeValue 屬性的值是null。如果元素包含了字符數據,則文字將被儲存于子Text 節點,而你可以從此Text 節點的nodeValue 屬性來存取字符數據。例如,如同前面范例所示,如果TITLE 元素的Element 節點包含文字「Moby-Dick」,則下面的程序代碼將提供TITLE 的字符數據「Moby-Dick」,而不含屬于SUBTITLE 的字符數據:
Element.firstChild.nodeValue
(因為TITLE 元素的字符數據位置在其子元素的前面,所以由第一個子節點來表示字符數據,因此你可以使用firstChild 屬性來擷取字符數據。)如果元素的字符數據與子元素、批注,或處理指令散置在一起,則每個個別的字符數據區塊將表示成為元素所屬的子Text 節點。例如,在下面范例中,ITEM 元素擁有三個子節點,其順序為:Text 節點表示第一個字符數據區塊,Element 節點表示子元素SUB-ITEM,而另一個Text 節點則代表第二個字符數據區塊:
<ITEM>
character data block 1
<SUB-ITEM>sub-item text</SUB-ITEM>
character data block 2
</ITEM>
表格9-5 分別列出Text 節點所提供的有用屬性和方式:
char-offset 為子字符串的起始位置,和num-chars 為子字符串的長度 SubString =Text.substringData(2,3); (從Text 元素的內容傳回第二、三、四等三個字符) 表格9-5 文字節點分別提供一個有用的屬性和方法,可使用的屬性也包括了表格9-2 中所列的共同節點屬性。
相關文章:
