XML DOM 流覽器差異


DOM 解析中的流覽器差異

所有現代的流覽器都支持 W3C DOM 規範。

然而,流覽器之間是有差異的。一個重要的差異是:

  • 處理空白和換行的方式

DOM - 空白和換行

XML 經常在節點之間包含換行或空白字元。這是在使用簡單的編輯器(比如記事本)編輯文檔時經常出現的情況。

下麵的例子(由記事本編輯)在每行之間包含 CR/LF(換行),在每個子節點之前包含兩個空格:

<book>
<title>Everyday Italian</title>
<author>Giada De Laurentiis</author>
<year>2005</year>
<price>30.00</price>
</book>

Internet Explorer 將不會把空的空白或換行作為文本節點,而其他流覽器會。

下麵的代碼片段顯示(books.xml 的)根元素擁有多少個子節點:

實例

xmlDoc=loadXMLDoc("books.xml");

x=xmlDoc.documentElement.childNodes;
document.write("Number of child nodes: " + x.length);

實例解釋:

  1. 使用 loadXMLDoc() 把 "books.xml" 載入 xmlDoc 中
  2. 獲取根元素的子節點
  3. 輸出子節點的數量。結果取決於您所使用的流覽器。IE 流覽器會輸出 4(提醒 4 個子節點),而其他流覽器會輸出 9(提醒 9 個子節點)。