ajax – XMLDom – Firefox

Firefox中的XML DOM

1, 创建
var oXmlDom = document.implementation.createDocument(“”, “books”, null);? //创建了一个XML DOM,其documentElement是<books/>
Firefox中创建一个XML DOM,需要调用document.implementation对象的createDocument()方法。该方法接受三个参数:第一个参数是包含文档所使用的命名空间URI的字符串;第二个参数是包含文档根元素名称的字符串;第三个参数是要创建的文档类型(也称为doctype),事实上,现在Firefox中并不提供针对文档类型的JavaScript支持,所以第三个参数总是为null

2,载入XML数据
(1) 将XML载入XML DOM的方法和微软采用的方法大致相同,只存在一个显著区别:Firefox只支持load()方法。因此,在这两种浏览器中载入外部XML数据的代码是相同的:

oXmlDom.load(“books.xml”);

(2) Firefox不支持readyState属性及onreadystatechange事件处理函数。在Firefox中,支持load事件和onload事件处理函数。在文档完全载入后将触发load事件:

oXmlDom.load(“books.xml”);

oXmlDom.onload = function () {

??? //文档完全载入后的操作

};

(3)在Firefox的XML DOM实现中,并没有loadXML()方法,不过通过Firefox中的DOMParser类可以模拟loadXML()的行为。该类有一个名为parseFromString()的方法,用来载入字符串并解析成文档:

var sXml = “<root><person><name>Jeremy McPeak</name></person></root>”;

var oParser = new DOMParser();

var oXmlDom = oParser.parseFromString(sXml,”text/xml”);


3,获取数据
(1)IE和Firefox中用于获取文档中XML数据的大多数属性和方法是一致的,

Firefox同样支持W3C标准属性,包括childNodes、firstChild、lastChild、nextSibling、nodeName、nodeType、nodeValue、ownerDocument、parentNode和previousSibling。不幸的是,对于微软专有的text和xml属性,Firefox并不支持,不过可以利用其他方法来模拟该属性的行为。如:

function getText(oNode) {

??? var sText = “”;

??? for (var i = 0; i < oNode.childNodes.length; i++) {

?????? if (oNode.childNodes[i].hasChildNodes()) {

?????????? sText += getText(oNode.childNodes[i]);

?????? } else {

?????????? sText += oNode.childNodes[i].nodeValue;

?????? }

??? }

??? return sText;

}

(2)序列化

IE中的xml属性将存放对当前节点包含的所有XML进行序列化的结果。在Firefox中,提供了一个名为XMLSerializer对象来完成这一功能。该对象提供一个使用JavaScript可访问的serializeToString()方法,使用该方法可以对XML数据进行序列化。

function serializeXml(oNode) {

??? var oSerializer = new XMLSerializer();

??? return oSerializer.serializeToString(oNode);

}

serializeXml()函数以XML节点作为参数,创建一个XMLSerializer对象,并将该节点传给serializeToString()方法。该方法将向调用者返回XML数据的字符串表示。

(3)对于节点操作的DOM方法,Firefox与IE大致相同

4,捕获错误

(1)当Firefox遇到错误时,它会将包含错误信息的XML文档载入到XML DOM文档中,当载入错误的XML时,XML DOM对象将会载入一个documentElement为<parsererror/>的错误文档。我们可以通过检查documentElement的tagName属性来确定是否发生错误。如果tagName属性不是parsererror,就可以确定没有发生任何错误。

if (oXmlDom.documentElement.tagName != “parsererror”) {

??? //没有错误发生,进行所需操作

} else {

??? alert(“An Error Occurred”);

}

(2)错误信息的提取

错误信息都包含在错误文档的文本中。如果要通过程序使用这些错误信息,那么首先就要对其进行解析。最简单的方法是使用一个稍长的正则表达式:

var reError = />([\s\S]*?)Location:([\s\S]*?)Line Number (\d+), Column

??? (\d+):<sourcetext>([\s\S]*?)(?:\-*\^)/;

该正则表达式将错误文档分为五个部分:错误消息、发生错误的文件名、行号、该行中发生错误的位置,以及发生错误的源代码。使用正则表达式对象的test()方法可以使用这些信息:

if (oXmlDom.firstChild.tagName != “parsererror”) {

??? //没有错误发生,进行所需操作

} else {

??? var oXmlSerializer = new XMLSerializer();

??? var sXmlError = oXmlSerializer.serializeToString(oXmlDom);

??? var reError = />([\s\S]*?)Location:([\s\S]*?)Line Number (\d+), Column

?????? (\d+):<sourcetext>([\s\S]*?)(?:\-*\^)/;

??? reError.test(sXmlError);

正则表达式捕获到的第一部分数据是错误消息,第二部分是文件名,第三部分是行号,第四部分是行内位置,第五部分是源码。