我有一个包含大量数据的大页面。有时我需要使用Ajax重新加载这些数据,所以ajax请求:
if (window.XMLHttpRequest) {
this._request = new XMLHttpRequest();
} else {
this._request = new ActiveXObject("Microsoft.XMLHTTP");
然后,我使用request.responseXML访问此数据。我遇到了一个问题,当责任的大小超过800k字符。
IE没有t generate responseXML, i
只是空XMLObject,但在responseText中,everithing就可以了。我试图使用以下代码解析XML:
if (request.responseXML) {
var responseXML = request.responseXML;
//TODO: for huge xml responses some versions of IE can't automaticly parse XML
if (O$.isExplorer && responseXML && !responseXML.firstChild) {
var originalResponseText = request.responseText;
if (window.DOMParser) {
var parser = new DOMParser();
responseXML = parser.parseFromString(originalResponseText, 'text/xml');
} else {
responseXML = new ActiveXObject("Microsoft.XMLDOM");
responseXML.async = false;
responseXML.loadXML(originalResponseText);
}
}
但我遇到了同样的问题。 然后,我尝试使用jQuery解析XML:
responseXML = jQuery.parseXml(request.responseXML);
但是问题仍然是一样的,当响应长度很小时一切都很好,但是对于巨大的响应我仍然得到空的XML对象,里面有解析错误。
errorCode:-2147467259
filepos:814853
原因:“未指定的错误\ r \ n”;
我检查响应字符串中的那些位置,一切都正确,只是一些序数符号。此外,我已经重新检查XML很多时间,我确信它是有效的。我根本不知道该怎么做。
另外我尝试编写自己的xml解析器,但我认为这个问题有更简单的解决方案。
先谢谢。
答案 0 :(得分:1)
IE似乎很难解析XML数据,并且可能没有那么多你可以真正做到这一点。一个解决方法是你可以尝试用IE解析XML数据,如果它失败了,构造一个新的解析器,它将从明文构建XML数据(正如你所提到的那样看似无论大小如何)。看看类似的问题并回答here。归结为(伪代码)
function() {
var XMLdata = reponse.XMLdata;
If (XMLdata.error) {
var parser = construct new DOMParser;
XMLdata = parser.XMLparse(response.plaintext);
}
return XMLdata;
}