尝试进行调用并检索一个非常简单的、只有一行的JSON文件。
$(document).ready(function() {
jQuery.ajax({
type: 'GET',
url: 'http://wncrunners.com/admin/colors.json' ,
dataType: 'jsonp',
success: function(data) {
alert('success');
}
});
});//end document.ready
以下是原始请求:
GET http://wncrunners.com/admin/colors.json?callback=jQuery16406345664265099913_1319854793396&_=1319854793399 HTTP/1.1
Host: wncrunners.com
Connection: keep-alive
Cache-Control: max-age=0
User-Agent: Mozilla/5.0 (Windows NT 6.1) AppleWebKit/535.2 (KHTML, like Gecko) Chrome/15.0.874.106 Safari/535.2
Accept: */*
Referer: http://localhost:8888/jquery/Test.html
Accept-Encoding: gzip,deflate,sdch
Accept-Language: en-US,en;q=0.8
Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.3
以下是原始响应内容:
HTTP/1.1 200 OK
Date: Sat, 29 Oct 2011 02:21:24 GMT
Server: Apache/1.3.33 (Unix) mod_ssl/2.8.22 OpenSSL/0.9.7d SE/0.5.3
Last-Modified: Fri, 28 Oct 2011 17:48:47 GMT
ETag: "166a2402-10-4eaaeaff"
Accept-Ranges: bytes
Content-Length: 16
Content-Type: text/plain
Connection: close
{"red" : "#f00"}
响应中返回了JSON (红色: #f00),但Chrome报告了Uncaught SyntaxError: Unexpected token : colors.json:1
如果我直接导航到URL本身,JSON将会被返回并在浏览器中显示。
如果我将colors.json的内容粘贴到JSLINT中,JSON将会验证通过。
有什么想法为什么我不能得到这个错误,并且我从来没有进入过成功回调?
EDIT - 上面的jQuery.ajax()调用在jsfiddle.net上运行得很好,并返回预期的警报“success”。
EDIT 2 - 此URL正常工作'http://api.wunderground.com/api/8ac447ee36aa2505/geolookup/conditions/q/IA/Cedar_Rapids.json' ,我注意到它返回为TYPE:text/javascript,而Chrome没有抛出Unexpected Token。 我测试了几个其他URL,唯一不抛出Unexptected Token的是以TYPE:text/javascript返回的wunderground。
返回为text/plain和application/json的流没有正确解析。