正如标题所暗示的那样,我有以下内容:
$.ajax({
"url" : ...
, "type" : "GET"
, "dataType" : "JSON"
, "success" : function(response_data) {
that.data = response_data;
success(response_data);
}
, "onerror" : function(data) {
console.log(JSON.stringify(data));
}
});
但是当我运行它时,我得到
XML Parsing Error: syntax error Location: moz-nullprincipal
看着萤火虫,我看到请求是
Accept application/json, text/javascript, */*; q=0.01
Accept-Encoding gzip, deflate
Accept-Language en-us,en;q=0.5
Cache-Control max-age=0
Connection keep-alive
Host localhost:8888
Referer http://localhost:8888/
User-Agent Mozilla/5.0 (Macintosh; Intel Mac OS X 10.7; rv:13.0) Gecko/20100101 Firefox/13.0.1
X-Requested-With XMLHttpRequest
有什么想法吗?
首先将"JSON"更改为小写的"json"。但这是jQuery期望从服务器返回的类型,不一定是服务器将发送的类型。
是否确定服务器返回 JSON?值得仔细检查。你看过《提琴手》中的回应吗?如果是 XML,则这是服务器的问题,而不是脚本的问题。
非常感谢大家试图回答这个问题。
但事实证明,像往常一样,我在这里哄骗了。
Firebug 中显示的 XML 解析错误实际上并不是代码错误,Firebug 尝试猜测它是 XML 并解析它失败。
我的问题在程序的其他地方,它得到了解决。
大写与小写"JSON"没有区别。
麦克斯
真正的问题是您的服务器没有设置"内容类型"标头。 将其设置为"应用程序/json"。
例如在节点.js中:
res.setHeader('Content-type', 'application/json');