在制作AJAX请求和处理响应方面,我遇到了一些奇怪的问题。
我正在为xml文件进行ajax调用。但是当我得到响应时,xhr.responseText属性在firefox中工作正常,但在IE中却没有。 另一件事是我试图访问xhr.responseXML作为XMLDocument,但它告诉我在Firefox中它告诉我xhr.responseXML未定义,即它甚至没有显示未定义的错误或显示输出。
这是我用来发出请求的代码:
var ajaxReq = function(url, callback) {
//initialize the xhr object and settings
var xhr = window.ActiveXObject ?
new ActiveXObject("Microsoft.XMLHTTP") : new XMLHttpRequest(),
//set the successful connection function
httpSuccess = function(xhr) {
try {
// IE error sometimes returns 1223 when it should be 204
// so treat it as success, see XMLHTTPRequest #1450
// this code is taken from the jQuery library with some modification.
return !xhr.status && xhr.status == 0 ||
(xhr.status >= 200 && xhr.status < 300) ||
xhr.status == 304 || xhr.status == 1223;
} catch (e) { }
return false;
};
//making sure the request is created
if (!xhr) {
return 404; // Not Found
}
//setting the function that is going to be called after the request is made
xhr.onreadystatechange = function() {
if (!httpSuccess(xhr)) {
return 503; //Service Unavailable
}
if (xhr.responseXML != null && xhr.responseText != null &&
xhr.responseXML != undefined && xhr.responseText != undefined) {
callback(xhr);
}
};
//open request call
xhr.open('GET', url, true);
//setup the headers
try {
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.setRequestHeader("Accept", "text/xml, application/xml, text/plain");
} catch ( ex ) {
window.alert('error' + ex.toString());
}
//send the request
try {
xhr.send('');
} catch (e) {
return 400; //bad request
}
return xhr;
};
这就是我调用函数来测试结果的方法:
window.onload = function() {
ajaxReq('ConferenceRoomSchedules.xml', function(xhr) {
//in firefox this line works fine,
//but in ie it doesnt not even showing an error
window.document.getElementById('schedule').innerHTML = xhr.responseText;
//firefox says ''xhr.responseXML is undefined'.
//and ie doesn't even show error or even alerts it.
window.alert(xhr.reponseXML.documentElement.nodeName);
});
}
这也是我第一次尝试使用AJAX,因此可能会有一些我看不对的东西。 我一直在疯狂寻找为什么或如何解决它的任何迹象,但没有运气。 任何想法都会很棒。
修改
我知道这对框架会更好,但老板不想为ajax功能添加框架('只是'对ajax来说不公平:P)。所以我用纯粹的javascript做这件事。
XML文件格式正确,我在网络浏览器中看得很清楚,但为了完成,这是我正在使用的测试文件:
<?xml version="1.0" encoding="utf-8"?>
<rooms>
<room id="Blue_Room">
<administrator>somebody@department</administrator>
<schedule>
<event>
<requester>
<name>Johnny Bravo</name>
<email>jbravo@department</email>
</requester>
<date>2009/09/03</date>
<start_time>11:00:00 GMT-0600</start_time>
<end_time>12:00:00 GMT-0600</end_time>
</event>
</schedule>
</room>
<room id="Red_Room">
<administrator>somebody@department</administrator>
<schedule>
</schedule>
</room>
<room id="Yellow_Room">
<administrator>somebody@department</administrator>
<schedule>
</schedule>
</room>
</rooms>
编辑2: 好消息是我说服我的老板使用jQuery,坏消息是AJAX仍然困扰着我。我会因为好奇而阅读更多关于它的内容。感谢您的提示,我向Heat Miser提供了答案,因为他是最接近的工作提示。
答案 0 :(得分:4)
几年前我遇到了同样的问题,然后我放弃了responseXML并开始使用responseText。这个解析函数一直对我有用:
function parseXml(xmlText){
try{
var text = xmlText;
//text = replaceAll(text,"<","<");
//text = replaceAll(text,">",">");
//text = replaceAll(text,""","\"");
//alert(text);
//var myWin = window.open('','win','resize=yes,scrollbars=yes');
//myWin.document.getElementsByTagName('body')[0].innerHTML = text;
if (typeof DOMParser != "undefined") {
// Mozilla, Firefox, and related browsers
var parser=new DOMParser();
var doc=parser.parseFromString(text,"text/xml");
//alert(text);
return doc;
}else if (typeof ActiveXObject != "undefined") {
// Internet Explorer.
var doc = new ActiveXObject("Microsoft.XMLDOM"); // Create an empty document
doc.loadXML(text); // Parse text into it
return doc; // Return it
}else{
// As a last resort, try loading the document from a data: URL
// This is supposed to work in Safari. Thanks to Manos Batsis and
// his Sarissa library (sarissa.sourceforge.net) for this technique.
var url = "data:text/xml;charset=utf-8," + encodeURIComponent(text);
var request = new XMLHttpRequest();
request.open("GET", url, false);
request.send(null);
return request.responseXML;
}
}catch(err){
alert("There was a problem parsing the xml:\n" + err.message);
}
}
使用此XMLHttpRequest对象:
// The XMLHttpRequest class object
debug = false;
function Request (url,oFunction,type) {
this.funct = "";
// this.req = "";
this.url = url;
this.oFunction = oFunction;
this.type = type;
this.doXmlhttp = doXmlhttp;
this.loadXMLDoc = loadXMLDoc;
}
function doXmlhttp() {
//var funct = "";
if (this.type == 'text') {
this.funct = this.oFunction + '(req.responseText)';
} else {
this.funct = this.oFunction + '(req.responseXML)';
}
this.loadXMLDoc();
return false;
}
function loadXMLDoc() {
//alert(url);
var functionA = this.funct;
var req;
req = false;
function processReqChange() {
// alert('reqChange is being called');
// only if req shows "loaded"
if (req.readyState == 4) {
// only if "OK"
if (req.status == 200) {
// ...processing statements go here...
eval(functionA);
if(debug){
var debugWin = window.open('','aWindow','width=600,height=600,scrollbars=yes');
debugWin.document.body.innerHTML = req.responseText;
}
} else {
alert("There was a problem retrieving the data:\n" +
req.statusText + '\nstatus: ' + req.status);
if(debug){
var debugWin = window.open('','aWindow','width=600,height=600,scrollbars=yes');
debugWin.document.body.innerHTML = req.responseText;
}
}
}
}
// branch for native XMLHttpRequest object
if(window.XMLHttpRequest) {
try {
req = new XMLHttpRequest();
} catch(e) {
req = false;
}
// branch for IE/Windows ActiveX version
} else if(window.ActiveXObject) {
try {
req = new ActiveXObject("Msxml2.XMLHTTP");
} catch(e) {
try {
req = new ActiveXObject("Microsoft.XMLHTTP");
} catch(e) {
req = false;
}
}
}
if(req) {
req.onreadystatechange = processReqChange;
if(this.url.length > 2000){
var urlSpl = this.url.split('?');
req.open("POST",urlSpl[0],true);
req.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
req.send(urlSpl[1]);
} else {
req.open("GET", this.url, true);
req.send("");
}
}
}
function browserSniffer(){
if(navigator.userAgent.toLowerCase().indexOf("msie") != -1){
if(navigator.userAgent.toLowerCase().indexOf("6")){
return 8;
}else{
return 1;
}
}
if(navigator.userAgent.toLowerCase().indexOf("firefox") != -1){
return 2;
}
if(navigator.userAgent.toLowerCase().indexOf("opera") != -1){
return 3;
}
if(navigator.userAgent.toLowerCase().indexOf("safari") != -1){
return 4;
}
return 5;
}
当然,这是一个非常古老的代码,但它在我几年前建立的网站上仍然适用于我。我同意其他所有人虽然我现在通常使用框架,所以我不必再使用这个代码或类似的东西了。
您可以在Request onreadystate函数中忽略拆分等的一些细节。如果请求超过一定长度,它应该将请求转换为帖子,但我只是觉得做帖子总是更好。
答案 1 :(得分:3)
当浏览器错误检测到内容类型或未正确发送内容类型时,会出现此问题。
更容易覆盖它:
var request = new XMLHttpRequest();
request.open("GET", url, false);
request.overrideMimeType("text/xml");
request.send(null);
return request.responseXML;
不确定原因......仅在Safari和Chrome(WebKit浏览器,服务器正确发送标题)时才会出现此问题。
答案 2 :(得分:1)
我建议您看一下隐藏和管理这些跨浏览器问题的框架(以可靠的方式)。这里的一个好点是jQuery。自己做这些事情会变得非常困难和复杂。
This可能就是您所需要的。
<强> //编辑:强> 这就是w3school显示它的方式:
function ajaxFunction()
{
var xmlhttp;
if (window.XMLHttpRequest)
{
// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else if (window.ActiveXObject)
{
// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
else
{
alert("Your browser does not support XMLHTTP!");
}
}
答案 3 :(得分:1)
您是否在调用相对于当前文档的URL?由于IE将使用ActiveXObject,因此可能需要绝对路径,例如:
http://some.url/ConferenceRoomSchedules.xml
至于XML,你确定它的格式正确吗?它是否在XML编辑器中加载,例如?
答案 4 :(得分:0)
为了避免您的跨浏览器问题(并且自己编写了很多强大的社区已经开发,测试和审核过的项目),您应该选择一个javascript库。 JQuery和Dojo是很好的选择。
答案 5 :(得分:0)
我相信您的网络服务器需要使用'ConferenceRoomSchedules.xml'来提供正确的响应标头,例如Content-Type:text / xml或任何其他xml类型。
答案 6 :(得分:0)
Aron在https://stackoverflow.com/a/2081466/657416中提供的答案从我的观点来看是最简单的(也是最好的)。这是我的工作代码:
ajax = ajaxRequest();
ajax.overrideMimeType("text/xml");
ajax.open("GET", myurl;