Go homepage(回首页)
Upload pictures (上传图片)
Write articles (发文字帖)

The author:(作者)归海一刀
published in(发表于) 2014/3/20 5:12:30
XML入门教程-XML 解析器_[XML教程]

XML入门教程:XML 解析器_[XML教程]

















如需读取、更新、创建或者操作某个XML文档,则需要XML解析器。




实例




解析XML文件 - 跨浏览器的实例




本例是一个跨浏览器的实例,把某个XML文档("note.xml")载入XML解析器。











解析XML字符串 - 跨浏览器的实例




本例是一个跨浏览器的实例,展示如何载入并解析某个XML字符串。











解析一个XML文档




如需操作某个XML文档,您需要XML解析器。解析器会将文档载入电脑的内存中。一旦文档被载入,可使用DOM对其数据进行操作。DOM把XML作为一颗树来处理。




微软的XML解析器与Mozilla浏览器中使用的解析器是有差异的。在本教程中,我们会为您展示如何创建可工作于IE和Mozilla浏览器中的跨浏览器脚本。




微软的XML解析器




微软的XML解析器是存在于IE 5.0或更高版本中的COM组件。一旦你安装了IE,就可使用脚本来利用解析器了。




微软的XML解析器支持所有必要的功能,来遍历节点树,访问节点以及它们的属性值,插入并删除节点,并将节点数转换回XML。




如需创建微软XML解析器的一个实例,请使用下面的代码:




JavaScript:
var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
VBScript:
set xmlDoc=CreateObject("Microsoft.XMLDOM")
ASP:
set xmlDoc=Server.CreateObject("Microsoft.XMLDOM")




下面的代码段可向微软的XML解析器载入一个已有的XML文档("note.xml"):




var xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.async="false";
xmlDoc.load("note.xml");




上面的脚本的第一行创建了XML解析器的一个实例。第二行关闭了同步载入,这样可以确保在文档被完全载入前解析器不会继续执行。第三行会告知解析器载入名为"note.xml"的XML的文档。




Mozilla、Firefox以及Opera中的XML解析器




Mozilla浏览器的XML解析器支持所有必要的功能,来遍历节点树,访问节点以及它们的属性值,插入并删除节点,并将节点树转换回XML。




如需创建Mozilla浏览器的XML解析器的一个实例,请使用下面的代码:




JavaScript:
var xmlDoc=document.implementation.createDocument("ns","root",null);




第一个参数,ns,定义用于XML文档的命名空间(namespace)。第二个参数,root,是XML文件中的XML根元素。第三个参数,null,一般总是null,这是由于目前还没有用到这个参数。




下面的代码段可向Mozilla浏览器的XML解析器载入一个已有的XML文档("note.xml"):




var xmlDoc=document.implementation.createDocument("","",null);
xmlDoc.load("note.xml");




上面的脚本的第一行创建了XML解析器的一个实例。第二行会告知解析器载入名为"note.xml"的XML的文档。




解析某个XML文件 - 跨浏览器的实例




下面的例子是一个跨浏览器的实例,向XML解析器载入了某个已有的XML文档("note.xml"):









W3Schools Internal Note


T

From:

Message:






输出:




W3Schools Internal Note
T Tove
From: Jani
Message: Don't forget me this weekend!




重要的注释




如需从某个XML元素(比如Jani)中提取文本(比如Jani),请使用下面的语法:




getElementsByTagName("from")[0].childNodes[0].nodeValue




重要事项:getElementsByTagName会返回一个节点数组。此数组含有XML文档中拥有指定名称的所有元素。在这例子中,只有一个"from"元素,但是仍然需要设定数组的下标( [0] )。




解析一个XML字符串 - 跨浏览器的实例




下面的代码是一个跨浏览器的实例,向我们展示了如何加载和解析某个XML字符串:











输出:




Text of first child element: Tove
Text of second child element: Jani




注释:Internet Explorer使用loadXML()方法解析XML字符串,而Mozilla浏览器使用DOMParser对象。

























If you have any requirements, please contact webmaster。(如果有什么要求,请联系站长)





QQ:154298438
QQ:417480759