我已经阅读了许多相同问题的Q& A,但没有我的具体问题(至少不是我能找到的).
header('Content-Type: application/json');
echo $result;
返回JSON(使用JSONLint检查并且有效):
{"Announcement":{"ID":1,"Type":1,"Text":"This is a test Albums announcement.","TimeStart":"1969-12-31","TimeEnd":"1969-12-31"}}
以及一个读取json的web jquery脚本:
$.ajax({
type : "GET",
url : "http://b***s.net/S****s/GetAnnouncements.PHP?callback=?",
data : {get_param : "Announcement"},
dataType : "json",
error : function(jqXHR, textStatus, errorThrown) {alert(errorThrown); alert(textStatus);},
success : function(data) {alert('success');
$.each(data, function(index, element) { alert('here');
$("#announcements-list").append("<li><a id='announcements-a-" + element.ID + "' href='#announcement-details'><p>" + element.Type + ": " + element.Text + "</p></a></li>");
$("#announcements-a-" + element.ID).bind('click', function() {Announcements.AnnouncementID = element.ID;});
});
$("#announcements-list").listview('refresh');
}
});
成功:从未被称为.和错误:返回textStatus“parsererror”,errorThrown是“错误:jQuery1830649454693285679_1359620502896未被调用”
>我添加了回调=?到网址解决跨域问题.
>我已发送标题(‘Content-Type:application / json’);到PHP,它返回NO HTML.
>我已经用JSONLint验证了JSON的有效性
>我尝试删除数据:“json”正如一些答案所说,但仍然会返回一个parsererror
>使用jQuery 1.8.3
解决方法:
您的服务器和客户端脚本不相互补充.您有两种选择:
使您的服务器端脚本返回JSON:
Content-Type: application/json
{"Announcement":{"ID":1}}
并省略回调参数:
$.ajax({
type : "GET",
url : "http://example.com/Feed/json.PHP",
dataType : "json"
});
使您的服务器端脚本返回JSONP,即JSON包含在回调函数中:
Content-Type: application/javascript
jQuery_xxxxxxxx({"Announcement":{"ID":1}});
并将数据类型更改为jsonp:
$.ajax({
type : "GET",
url : "http://example.com/Feed/json.PHP",
dataType : "jsonp"
});
请注意,jQuery会默默地将& callback = jQuery_xxxxxxxx附加到此类请求的URL.
服务器应使用URL中指定的回调名称.你可以这样做:
echo sprintf(
"%s(%s);",
isset($_GET["callback"]) ? $_GET["callback"] : "void",
json_encode($data)
);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。