主页 > 知识库 > 完美解决ajax跨域请求下parsererror的错误

完美解决ajax跨域请求下parsererror的错误

热门标签:Linux服务器 团购网站 Mysql连接数设置 服务器配置 科大讯飞语音识别系统 阿里云 电子围栏 银行业务

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的错误就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • Jax-rs规范REST接口文件上传代码实例
  • Ajax跨域问题及解决方案(jsonp,cors)
  • Springboot解决ajax+自定义headers的跨域请求问题
  • 浅谈Koa2框架利用CORS完成跨域ajax请求
  • Javaweb使用cors完成跨域ajax数据交互
  • jQuery.ajax 跨域请求webapi设置headers的解决方案
  • 空格或者空白字符导致$.ajax()报parseerror错误小结
  • Jax-rs规范下REST接口使用方法详解

标签:广元 萍乡 枣庄 蚌埠 衡水 大理 衢州 江苏

巨人网络通讯声明:本文标题《完美解决ajax跨域请求下parsererror的错误》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266