完美解决ajax跨域请求下parsererror的错误
ajax请求报parsererror错误是很宽泛的概念,很多情况下都报这个错,
在很多时候,即使ajax提交、返回都正常
xmlhttprequest.status=200 (正常响应)
xmlhttprequest.readystate=4 (正常接收)
ajax也会提示一个parseerror的错误.
出现这个错误,大都是不良书写习惯,或者语法不当造成的.
关于ajax的错误,请使用:
error:function(xmlhttprequest, textstatus, errorthrown){ $("div").html(textstatus); $("div").append("<br/>"xmlhttprequest.status); $("div").append("<br/>"xmlhttprequest.readystate); $("div").append("<br/>"xmlhttprequest.responsetext); }
或:
$("div").ajaxerror(function(event,request, settings){ $(this).append("<li>出错页面:" + settings.url + "</li>"); });
取得错误相关信息,以进行分析.
textstatus返回除了得到null,"timeout", "error", "notmodified" 和 "parsererror"。
xmlhttprequest对象可以使用status,readystate,responsetext等属性取得http代码,处理状态和服务器返回的文字内容.
在使用ajax,以及相关应用开发过程中,一定要按标准写程序,可以减少出错的机率.
这个标准包括语法,数据格式,标点符号等.
ajax跨请求中,如果data为空,请使用;
data:"{}",
ajax处理服务器返回json格式数据时,如果采用$.parsejson()方式,
那么服务器返回的json数据格式,一定按标准json格式书写,
对字符而言必须用双引号代替单引号包围,数值,布尔类型,null不用,
这点主要在一些老的jquery版本上发生单引号,双引号的不同而出现错误提示.
ajax跨域请求(jsonp)中,服务端返回数据格式必须是:
mycallbackfunction({"id":1,"name":"c#","is_familiar":true});
请注意这个函数最后的分号";",必须加上,
否则,如果同一个页面有多个ajax请求,并且在数据没有返回时,再发出其它ajax请求时,
有可能出现parsererror出错提示.
这种错误很隐敝,在开发时,不容易发现,在并发测试时,就很容易暴露出.
以上这篇完美解决ajax跨域请求下parsererror的错误就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
下一篇: Ajax动态为下拉列表添加数据的实现方法