JavaScript操作XML (一)

原創 JavaScript操作XML (一)收藏

JavaScript操作XML是通過XML DOM來完成的。
那麼什麼是XML DOM呢?
XML DOM 是:
  • 用於 XML 的標準對象模型
  • 用於 XML 的標準編程接口
  • 中立於平臺和語言
  • W3C 的標準
XML DOM 定義了所有XML 元素的對象和屬性,以及訪問它們的方法(接口)。
也就是說:
XML DOM 是用於查詢、添加、修改、刪除XML 元素的標準。


在繼續之前,我們先來了解一下XML的定義。
請看下面的 XML 文件 (books.xml):

<?xml version="1.0" encoding="utf-8"?>
<bookstore>
<book category="COOKING">
  <title lang="en">Everyday Italian</title>
  <author>Giada De Laurentiis</author>
  <year>2005</year>
  <price>30.00</price>
</book>
<book category="CHILDREN">
  <title lang="en">Harry Potter</title>
  <author>J K. Rowling</author>
  <year>2005</year>
  <price>29.99</price>
</book>
<book category="WEB">
  <title lang="en">XQuery Kick Start</title>
  <author>James McGovern</author>
  <author>Per Bothner</author>
  <author>Kurt Cagle</author>
  <author>James Linn</author>
  <author>Vaidyanathan Nagarajan</author>
  <year>2003</year>
  <price>49.99</price>
</book>
<book category="WEB">
  <title lang="en">Learning XML</title>
  <author>Erik T. Ray</author>
  <year>2003</year>
  <price>39.95</price>
</book>
</bookstore>
在上面的 XML 中,根節點是 <bookstore>。文檔中的所有其他節點都被包含在 <bookstore> 中。
根節點 <bookstore> 有四個 <book> 節點。
第一個 <book> 節點有四個節點:<title>, <author>, <year> 以及 <price>,其中每個節點都包含一個文本節點,"Everyday Italian", "Giada De Laurentiis", "2005" 以及 "30.00"。

XML 文檔中的每個成分都是一個節點。

節點

根據 DOM,XML 文檔中的每個成分都是一個節點。
DOM 是這樣規定的:
  • 整個文檔是一個文檔節點
  • 每個 XML 標籤是一個元素節點
  • 包含在 XML 元素中的文本是文本節點
  • 每一個 XML 屬性是一個屬性節點
  • 註釋屬於註釋節點

文本總是存儲在文本節點中

在 DOM 處理中一個普遍的錯誤是,認爲元素節點包含文本。
不過,元素節點的文本是存儲在文本節點中的。
在這個例子中:<year>2005</year>,元素節點 <year>,擁有一個值爲 "2005" 的文本節點。
2005" 不是 <year> 元素的值!

XML DOM 把 XML DOM 文檔視爲一棵節點樹 (node-tree)。
樹中的所有節點彼此之間都有關係。

XML DOM 節點樹

XML DOM 把 XML 文檔視爲一種樹結構。這種樹結構被稱爲節點樹。
可通過這棵樹訪問所有節點。可以修改或刪除它們的內容,也可以創建新的元素。
這顆節點樹展示了節點的集合,以及它們之間的聯繫。這棵樹從根節點開始,然後在樹的最低層級向文本節點長出枝條:
DOM

父、子和兄弟節點

節點樹中的節點彼此之間都有等級關係。
父、子和兄弟節點用於描述這種關係。父節點擁有子節點,位於相同層級上的子節點稱爲兄弟節點。
  • 在節點樹中,頂端的節點成爲根節點
  • 根節點之外的每個節點都有一個父節點
  • 節點可以有任何數量的子節點
  • 葉子是沒有子節點的節點
  • 兄弟節點是擁有相同父節點的節點  
在上面的 XML 中,<title> 元素是 <book> 元素的第一個子節點,而 <price> 元素是 <book> 元素的最後一個子節點。
此外,<book> 元素是 <title>、<author>、<year> 以及 <price> 元素的父節點。
Note: 父節點:Parent Node,子節點:Children Node,同級節點:Sibling Node
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章