- ·上一篇站长学习:关系营销的网络化变革
- ·下一篇站长学习:Google正改变AdSense广告的可点击区域
XML入门教程:XML 解析器
如需读取、更新、创建或者操作某个XML文档,则需要XML解析器。 [我要我当软件园]
解析XML文件 - 跨浏览器的实例 515down
本例是一个跨浏览器的实例,把某个XML文档("note.xml")载入XML解析器。 515down
| 以下为引用的内容: <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字符串。
我要我当
| 以下为引用的内容: <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> |
解析一个XML文档
Www~515down~com
如需操作某个XML文档,您需要XML解析器。解析器会将文档载入电脑的内存中。一旦文档被载入,可使用DOM对其数据进行操作。DOM把XML作为一颗树来处理。 我要我当
微软的XML解析器与Mozilla浏览器中使用的解析器是有差异的。在本教程中,我们会为您展示如何创建可工作于IE和Mozilla浏览器中的跨浏览器脚本。 Www.515down.com
微软的XML解析器是存在于IE 5.0或更高版本中的COM组件。一旦你安装了IE,就可使用脚本来利用解析器了。 我要我当软件园
微软的XML解析器支持所有必要的功能,来遍历节点树,访问节点以及它们的属性值,插入并删除节点,并将节点数转换回XML。
515down@com
如需创建微软XML解析器的一个实例,请使用下面的代码: 我要我当
| 以下为引用的内容: JavaScript: var xmlDoc=new ActiveXObject("Microsoft.XMLDOM"); |
515down@com
上面的脚本的第一行创建了XML解析器的一个实例。第二行关闭了同步载入,这样可以确保在文档被完全载入前解析器不会继续执行。第三行会告知解析器载入名为"note.xml"的XML的文档。
我要我当
Mozilla、Firefox以及Opera中的XML解析器
Www@515down@com
Mozilla浏览器的XML解析器支持所有必要的功能,来遍历节点树,访问节点以及它们的属性值,插入并删除节点,并将节点树转换回XML。 Www@515down@com
如需创建Mozilla浏览器的XML解析器的一个实例,请使用下面的代码:
515down^com
| 以下为引用的内容: JavaScript: var xmlDoc=document.implementation.createDocument("ns","root",null); |
第一个参数,ns,定义用于XML文档的命名空间(namespace)。第二个参数,root,是XML文件中的XML根元素。第三个参数,null,一般总是null,这是由于目前还没有用到这个参数。 Www~515down~com
下面的代码段可向Mozilla浏览器的XML解析器载入一个已有的XML文档("note.xml"):
中国我要我当
| 以下为引用的内容: var xmlDoc=document.implementation.createDocument("","",null); xmlDoc.load("note.xml"); |
上面的脚本的第一行创建了XML解析器的一个实例。第二行会告知解析器载入名为"note.xml"的XML的文档。 我要我当软件园
下面的例子是一个跨浏览器的实例,向XML解析器载入了某个已有的XML文档("note.xml"):
515down~com
| 以下为引用的内容: <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> |
输出:
515down~com
| 以下为引用的内容: W3Schools Internal Note To: Tove From: Jani Message: Don't forget me this weekend! |
重要的注释 我要我当
如需从某个XML元素(比如<from>Jani</from>)中提取文本(比如Jani),请使用下面的语法: 我要我当
getElementsByTagName("from")[0].childNodes[0].nodeValue
515down_com
重要事项:getElementsByTagName会返回一个节点数组。此数组含有XML文档中拥有指定名称的所有元素。在这例子中,只有一个"from"元素,但是仍然需要设定数组的下标






