XML入門教程:XML 解析器_Xml教程
推薦:XML 中的常見(jiàn)問(wèn)題(一)一般問(wèn)題 什么是 XML? 可擴(kuò)展標(biāo)記語(yǔ)言 (XML) 是 Web 上的數(shù)據(jù)通用語(yǔ)言。它使開(kāi)發(fā)人員能夠?qū)⒔Y(jié)構(gòu)化數(shù)據(jù),從許多不同的應(yīng)用程序傳遞到桌面,進(jìn)行本地計(jì)算和演示。XML 允許為特定應(yīng)用程序創(chuàng)建
如需讀取、更新、創(chuàng)建或者操作某個(gè)XML文檔,則需要XML解析器。
實(shí)例
解析XML文件 - 跨瀏覽器的實(shí)例
本例是一個(gè)跨瀏覽器的實(shí)例,把某個(gè)XML文檔("note.xml")載入XML解析器。
| 以下為引用的內(nèi)容: <html> <body> <script type="text/vbscript"> set xmlDoc=CreateObject("Microsoft.XMLDOM") xmlDoc.async="false" xmlDoc.load("/example/xmle/xmle_xml_note.xml") document.write("<h1>Traversing the XML nodes</h1>") for each x in xmlDoc.documentElement.childNodes document.write("<b>" & x.nodename & "</b>") document.write(": ") document.write(x.text) document.write("<br><br>") next </script> </body> </html> |
解析XML字符串 - 跨瀏覽器的實(shí)例
本例是一個(gè)跨瀏覽器的實(shí)例,展示如何載入并解析某個(gè)XML字符串。
| 以下為引用的內(nèi)容: <html> <body> <script type="text/javascript"> var xmlDoc = new ActiveXObject("Microsoft.XMLDOM") xmlDoc.async="false" xmlDoc.load("/example/xmle/xmle_xml_note.xml") document.write ("The first XML element in the file contains: ") document.write (xmlDoc.documentElement.childNodes.item(0).text) </script> </body> </html> |
解析一個(gè)XML文檔
如需操作某個(gè)XML文檔,您需要XML解析器。解析器會(huì)將文檔載入電腦的內(nèi)存中。一旦文檔被載入,可使用DOM對(duì)其數(shù)據(jù)進(jìn)行操作。DOM把XML作為一顆樹(shù)來(lái)處理。
微軟的XML解析器與Mozilla瀏覽器中使用的解析器是有差異的。在本教程中,我們會(huì)為您展示如何創(chuàng)建可工作于IE和Mozilla瀏覽器中的跨瀏覽器腳本。
微軟的XML解析器
微軟的XML解析器是存在于IE 5.0或更高版本中的COM組件。一旦你安裝了IE,就可使用腳本來(lái)利用解析器了。
微軟的XML解析器支持所有必要的功能,來(lái)遍歷節(jié)點(diǎn)樹(shù),訪問(wèn)節(jié)點(diǎn)以及它們的屬性值,插入并刪除節(jié)點(diǎn),并將節(jié)點(diǎn)數(shù)轉(zhuǎn)換回XML。
如需創(chuàng)建微軟XML解析器的一個(gè)實(shí)例,請(qǐng)使用下面的代碼:
| 以下為引用的內(nèi)容: JavaScript: var xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); |
上面的腳本的第一行創(chuàng)建了XML解析器的一個(gè)實(shí)例。第二行關(guān)閉了同步載入,這樣可以確保在文檔被完全載入前解析器不會(huì)繼續(xù)執(zhí)行。第三行會(huì)告知解析器載入名為"note.xml"的XML的文檔。
Mozilla、Firefox以及Opera中的XML解析器
Mozilla瀏覽器的XML解析器支持所有必要的功能,來(lái)遍歷節(jié)點(diǎn)樹(shù),訪問(wèn)節(jié)點(diǎn)以及它們的屬性值,插入并刪除節(jié)點(diǎn),并將節(jié)點(diǎn)樹(shù)轉(zhuǎn)換回XML。
如需創(chuàng)建Mozilla瀏覽器的XML解析器的一個(gè)實(shí)例,請(qǐng)使用下面的代碼:
| 以下為引用的內(nèi)容: JavaScript: var xmlDoc=document.implementation.createDocument("ns","root",null); |
第一個(gè)參數(shù),ns,定義用于XML文檔的命名空間(namespace)。第二個(gè)參數(shù),root,是XML文件中的XML根元素。第三個(gè)參數(shù),null,一般總是null,這是由于目前還沒(méi)有用到這個(gè)參數(shù)。
下面的代碼段可向Mozilla瀏覽器的XML解析器載入一個(gè)已有的XML文檔("note.xml"):
| 以下為引用的內(nèi)容: var xmlDoc=document.implementation.createDocument("","",null); xmlDoc.load("note.xml"); |
上面的腳本的第一行創(chuàng)建了XML解析器的一個(gè)實(shí)例。第二行會(huì)告知解析器載入名為"note.xml"的XML的文檔。
解析某個(gè)XML文件 - 跨瀏覽器的實(shí)例
下面的例子是一個(gè)跨瀏覽器的實(shí)例,向XML解析器載入了某個(gè)已有的XML文檔("note.xml"):
| 以下為引用的內(nèi)容: <html> <head> <script type="text/javascript"> var xmlDoc; function loadXML() { // 用于 IE 的代碼: if (window.ActiveXObject) { xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); xmlDoc.async=false; xmlDoc.load("note.xml"); getmessage(); } // 用于 Mozilla, Firefox, Opera, 等瀏覽器的代碼: else if (document.implementation && document.implementation.createDocument) { xmlDoc=document.implementation.createDocument("","",null); xmlDoc.load("note.xml"); xmlDoc.onload=getmessage; } else { alert('Your browser cannot handle this script'); } } function getmessage() { document.getElementById("to").innerHTML= xmlDoc.getElementsByTagName("to")[0].childNodes[0].nodeValue; document.getElementById("from").innerHTML= xmlDoc.getElementsByTagName("from")[0].childNodes[0].nodeValue; document.getElementById("message").innerHTML= xmlDoc.getElementsByTagName("body")[0].childNodes[0].nodeValue; } </script> </head> <body onload="loadXML()"> <h1>W3Schools Internal Note</h1> <p><b>To:</b> <span id="to"></span><br /> <b>From:</b> <span id="from"></span><br /> <b>Message:</b> <span id="message"></span> </p> </body> </html> |
輸出:
| 以下為引用的內(nèi)容: W3Schools Internal Note To: Tove From: Jani Message: Don't forget me this weekend! |
重要的注釋
如需從某個(gè)XML元素(比如<from>Jani</from>)中提取文本(比如Jani),請(qǐng)使用下面的語(yǔ)法:
getElementsByTagName("from")[0].childNodes[0].nodeValue
重要事項(xiàng):getElementsByTagName會(huì)返回一個(gè)節(jié)點(diǎn)數(shù)組。此數(shù)組含有XML文檔中擁有指定名稱的所有元素。在這例子中,只有一個(gè)"from"元素,但是仍然需要設(shè)定數(shù)組的下標(biāo)( [0] )。
解析一個(gè)XML字符串 - 跨瀏覽器的實(shí)例
下面的代碼是一個(gè)跨瀏覽器的實(shí)例,向我們展示了如何加載和解析某個(gè)XML字符串:
| 以下為引用的內(nèi)容: <html> <body> <script type="text/javascript"> var text="<note>"; text=text "<to>Tove</to>"; text=text "<from>Jani</from>"; text=text "<heading>Reminder</heading>"; text=text "<body>Don't forget me this weekend!</body>"; text=text "</note>"; // 用于 IE 的代碼: if (window.ActiveXObject) { var doc=new ActiveXObject("Microsoft.XMLDOM"); doc.async="false"; doc.loadXML(text); } // 用于 Mozilla, Firefox, Opera, 等瀏覽器的代碼: else { var parser=new DOMParser(); var doc=parser.parseFromString(text,"text/xml"); } // documentElement 提交根元素: var x=doc.documentElement; document.write("Text of first child element: "); document.write(x.childNodes[0].childNodes[0].nodeValue); document.write("<br />"); document.write("Text of second child element: "); document.write(x.childNodes[1].childNodes[0].nodeValue); </script> </body> </html> |
輸出:
| 以下為引用的內(nèi)容: Text of first child element: Tove Text of second child element: Jani |
注釋:Internet Explorer使用loadXML()方法解析XML字符串,而Mozilla瀏覽器使用DOMParser對(duì)象。
分享:揭穿 XQuery 的神話和誤解 XQuery 給軟件架構(gòu)師和開(kāi)發(fā)人員帶來(lái)了很多希望,因?yàn)榇蟠鬁p少了建立使用 XML 的服務(wù)所需要編寫(xiě)的代碼量。您也許認(rèn)為 XQuery 所做的一切很容易理解,但是在 XQuery 的軟件開(kāi)發(fā)社區(qū)中仍然存在著
- xml創(chuàng)建節(jié)點(diǎn)(根節(jié)點(diǎn)、子節(jié)點(diǎn))
- WML開(kāi)發(fā)教程之 WAP網(wǎng)站服務(wù)器配置方法
- WMLScript的語(yǔ)法基礎(chǔ)
- 收集的WML Script標(biāo)準(zhǔn)函數(shù)庫(kù)
- WML教程之文本框控件Input
- 無(wú)線標(biāo)記語(yǔ)言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)
- xml文件的結(jié)構(gòu)解讀
- 關(guān)于XSL - XSL教程
- 選擇模式 - XSL教程 - 2
- XPath入門 - XSL教程 - 3
- 匹配模式 - XSL教程 - 4
- 測(cè)試模式 - XSL教程 - 5
- 相關(guān)鏈接:
- 教程說(shuō)明:
Xml教程-XML入門教程:XML 解析器
。