所有現代瀏覽器都內建了供讀取和操作 XML 的 XML 解析器。
解析器把 XML 轉換為 XML DOM 對象 - 可通過 JavaScript 操作的對象。
W3School 提供的實例是獨立于瀏覽器和平臺的。這些例子可以在所有現代瀏覽器中運行。
所有現代瀏覽器都有讀取和操作 XML 的內建 XML 解析器。
解析器把 XML 載入內存,然后把它轉換為可通過 JavaScript 訪問的 XML DOM 對象。
您將在本教程的下一節中學習更多有關 XML DOM 的知識。
微軟的 XML 解析器與其他瀏覽器中的解析器之間,存在一些差異。微軟的解析器支持 XML 文件和 XML 字符串(文本)的加載,而其他瀏覽器使用單獨的解析器。不過,所有的解析器都包含遍歷 XML 樹、訪問插入及刪除節點(元素)及其屬性的函數。
在本教程中,我們將為您展示如何創建可同時工作于 Internet Explorer 和其他瀏覽器中的腳本。
注釋:當我們談及 XML 解析,我們常常會使用有關 XML 元素的術語:節點。
下面的代碼片段把 XML 文檔解析到 XML DOM 對象中:
if (window.XMLHttpRequest) {// code for IE7+, Firefox, Chrome, Opera, Safari xmlhttp=new XMLHttpRequest()
; }else {// code for IE6, IE5 xmlhttp=new ActiveXObject("Microsoft.XMLHTTP")
; }xmlhttp.open("GET","books.xml",false);xmlhttp.send();xmlDoc=xmlhttp.responseXML;
微軟的 XML 解析器內建于 Internet Explorer 5 以及更高的版本中。
下面的 JavaScript 片段把一個 XML 文檔載入解析器中:
var xmlDoc=new ActiveXObject("Microsoft.XMLDOM")
;xmlDoc.async="false";xmlDoc.load("note.xml");
下面的 JavaScript 片段把 XML 文檔 ("note.xml") 載入解析器:
var xmlDoc=document.implementation.createDocument("","",null)
;xmlDoc.async="false";xmlDoc.load("note.xml");
下面的 JavaScript 代碼片段把 XML 字符串解析到 XML DOM 對象中(把字符串 txt 載入解析器):
txt="";if (window.DOMParser) { parser= ";txt=txt+" Everyday Italian ";txt=txt+"Giada De Laurentiis";txt=txt+"2005 ";txt=txt+"new DOMParser()
; xmlDoc=parser.parseFromString(txt,"text/xml"); }else // Internet Explorer { xmlDoc=new ActiveXObject("Microsoft.XMLDOM")
; xmlDoc.async="false"; xmlDoc.loadXML(txt); }
注釋:Internet Explorer 使用 loadXML() 方法來解析 XML 字符串,而其他瀏覽器使用 DOMParser 對象。
注釋:loadXML() 方法用于加載字符串(文本),load() 用于加載文件。
出于安全方面的原因,現代的瀏覽器不允許跨域的訪問。
這意味著,網頁以及它試圖加載的 XML 文件,都必須位于相同的服務器上。
W3School 的實例所打開的 XML 文件位于 W3School 的域上。
假如你打算在自己的網頁上使用上面的例子,則必須把 XML 文件放到自己的服務器上。否則,xmlDoc.load() 將產生錯誤 "Access is denied"。
在本教程的下一章節,您將學習如何訪問 XML 文檔對象 (XML DOM) 并取回數據。
新聞熱點
疑難解答