作者:Y死一般的痛过 | 来源:互联网 | 2014-05-04 00:43
如需读取、更新、创立或者把持某个XML文档,则需要XML解析器。实例解析XML文件-跨浏览器的实例本例是一个跨浏览器的实例,把某个XML文档("note.xml")载进XML解析器。htmlbodyscript
如需读取、更新、创立或者把持某个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
To:
From:
Message:
输出:
W3Schools Internal Note
To: 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对象。