Jquery Ajax Error 调试错误的技巧


Posted in Javascript onNovember 20, 2015

JQuery使我们在开发Ajax应用程序的时候提高了效率,减少了许多兼容性问题,我们在Ajax项目中,遇到ajax异步获取数据出错怎么办,我们可以通过捕捉error事件来获取出错的信息。

在没给大家介绍正文之前先给分享Jquery中AJAX参数详细列表:

参数名 类型 描述
url String (默认: 当前页地址) 发送请求的地址。
type String (默认: "GET") 请求方式 ("POST" 或 "GET"), 默认为 "GET"。注意:其它 HTTP 请求方法,如 PUT 和 DELETE 也可以使用,但仅部分浏览器支持。
timeout Number 设置请求超时时间(毫秒)。此设置将覆盖全局设置。
async Boolean (默认: true) 默认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。
beforeSend Function 发送请求前可修改 XMLHttpRequest 对象的函数,如添加自定义 HTTP 头。XMLHttpRequest 对象是唯一的参数。function (XMLHttpRequest) {this; // the options for this ajax request}
cache Boolean (默认: true) jQuery 1.2 新功能,设置为 false 将不会从浏览器缓存中加载请求信息。
complete Function 请求完成后回调函数 (请求成功或失败时均调用)。参数: XMLHttpRequest 对象,成功信息字符串。function (XMLHttpRequest, textStatus) {this; // the options for this ajax request}
contentType String (默认: "application/x-www-form-urlencoded") 发送信息至服务器时内容编码类型。默认值适合大多数应用场合。
data Object, String 发 送到服务器的数据。将自动转换为请求字符串格式。GET 请求中将附加在 URL 后。查看 processData 选项说明以禁止此自动转换。必须为 Key/Value 格式。如果为数组,jQuery 将自动为不同值对应同一个名称。如 {foo:["bar1", "bar2"]} 转换为 '&foo=bar1&foo=bar2'。
dataType String 预期服务器返回的数据类型。如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息返回 responseXML 或 responseText,并作为回调函数参数传递,可用值: "xml": 返回 XML 文档,可用 jQuery 处理。 "html": 返回纯文本 HTML 信息;包含 script 元素。 "script": 返回纯文本 JavaScript 代码。不会自动缓存结果。 "json": 返回 JSON 数据 。 "jsonp": JSONP 格式。使用 JSONP 形式调用函数时,如 "myurl?callback=?" jQuery 将自动替换 ? 为正确的函数名,以执行回调函数。
error Function (默认: 自动判断 (xml 或 html)) 请求失败时将调用此方法。这个方法有三个参数:XMLHttpRequest 对象,错误信息,(可能)捕获的错误对象。function (XMLHttpRequest, textStatus, errorThrown) {// 通常情况下textStatus和errorThown只有其中一个有值 this; // the options for this ajax request}
global Boolean (默认: true) 是否触发全局 AJAX 事件。设置为 false 将不会触发全局 AJAX 事件,如 ajaxStart 或 ajaxStop 。可用于控制不同的Ajax事件
ifModified Boolean (默认: false) 仅在服务器数据改变时获取新数据。使用 HTTP 包 Last-Modified 头信息判断。
processData Boolean (默认: true) 默认情况下,发送的数据将被转换为对象(技术上讲并非字符串) 以配合默认内容类型 "application/x-www-form-urlencoded"。如果要发送 DOM 树信息或其它不希望转换的信息,请设置为 false。
success Function 请求成功后回调函数。这个方法有两个参数:服务器返回数据,返回状态function (data, textStatus) {// data could be xmlDoc, jsonObj, html, text, etc...this; // the options for this ajax request}

jquery中ajax的常用用法类似于:

JScript 代码  

$(document).ready(function() {
      jQuery("#clearCac").click(function() {
        jQuery.ajax({
          url: url,
          type: "post",
          data: { id: '0' },
          dataType: "json",
          success: function(msg) {
            alert(msg);
          },
          error: function(XMLHttpRequest, textStatus, errorThrown) {
            alert(XMLHttpRequest.status);
            alert(XMLHttpRequest.readyState);
            alert(textStatus);
          },
          complete: function(XMLHttpRequest, textStatus) {
            this; // 调用本次AJAX请求时传递的options参数
          }
        });
      });
    });

当通过ajax异步调用成功时,会调用 success函数 。success函数语法为:

//请求成功后回调函数。这个方法有两个参数:服务器返回数据,返回状态


 function (data, textStatus)
 {
  // data could be xmlDoc, jsonObj, html, text, etc...   
  this;
 // the options for this ajax request
 }
当通过ajax异步调用出错时,会调用 error函数 。error函数语法为:
//(默 认: 自动判断 (xml 或 html)) 请求失败时调用时间。参数有以下三个:XMLHttpRequest 对象、错误信息、(可选)捕获的错误对象。如果发生了错误,错误信息(第二个参数)除了得到null之外,还可能是"timeout", "error", "notmodified" 和 "parsererror"。
//textStatus: "timeout", "error", "notmodified" 和 "parsererror"。
error:function (XMLHttpRequest, textStatus, errorThrown) 
{ 
}

error事件返回的第一个参数XMLHttpRequest:

XMLHttpRequest.readyState: 状态码的意思

0 - (未初始化)还没有调用send()方法
1 - (载入)已调用send()方法,正在发送请求
2 - (载入完成)send()方法执行完成,已经接收到全部响应内容
3 - (交互)正在解析响应内容
4 - (完成)响应内容解析完成,可以在客户端调用了

发送error可能有下面两张引起的,或者其他程序问题,需要我们认真仔细。

1、data:"{}", data为空也一定要传"{}";不然返回的是xml格式的。并提示parsererror.
2、parsererror的异常和Header 类型也有关系。及编码header('Content-type: text/html; charset=utf8');

以上内容是小编给大家分享关于Jquery Ajax Error 调试错误的技巧,希望大家喜欢。

Javascript 相关文章推荐
Javascript中arguments对象详解
Oct 22 Javascript
使用jquery动态加载js文件的方法
Dec 24 Javascript
跟我学习javascript的作用域与作用域链
Nov 19 Javascript
js文本框输入内容智能提示效果
Dec 02 Javascript
JavaScript原生xmlHttp与jquery的ajax方法json数据格式实例
Dec 04 Javascript
BootStrap入门教程(三)之响应式原理
Sep 19 Javascript
Jquery Easyui自定义下拉框组件使用详解(21)
Dec 31 Javascript
NPM 安装cordova时警告:npm WARN deprecated minimatch@2.0.10: Please update to minimatch 3.0.2 or higher to
Dec 20 Javascript
详解如何让InstantClick兼容MathJax、百度统计等
Sep 12 Javascript
Bootstrap fileinput 上传新文件移除时触发服务器同步删除的配置
Oct 08 Javascript
Vue实现table上下移动功能示例
Feb 21 Javascript
解决vue项目运行npm run serve报错的问题
Oct 26 Javascript
jQuery实现简单的文件上传进度条效果
Mar 26 #Javascript
jquery实现手风琴效果
Nov 20 #Javascript
不想让浏览器运行javascript脚本的方法
Nov 20 #Javascript
jquery背景跟随鼠标滑动导航
Nov 20 #Javascript
JavaScript获取浏览器信息的方法
Nov 20 #Javascript
JavaScript性能优化之小知识总结
Nov 20 #Javascript
Bootstrap每天必学之基础排版
Nov 20 #Javascript
You might like
php小型企业库存管理系统的设计与实现代码
2011/05/16 PHP
php魔术方法与魔术变量、内置方法与内置变量的深入分析
2013/06/03 PHP
php编写的抽奖程序中奖概率算法
2015/05/14 PHP
Zend Framework实现自定义过滤器的方法
2016/12/09 PHP
php利用云片网实现短信验证码功能的示例代码
2017/11/18 PHP
jquery自定义滚动条插件示例分享
2014/02/21 Javascript
使用js画图之圆、弧、扇形
2015/01/12 Javascript
javascript引用类型指针的工作方式
2015/04/13 Javascript
JavaScript检查数字是否为整数或浮点数的方法
2015/06/09 Javascript
jQuery过滤选择器用法示例
2016/09/12 Javascript
Javascript 获取鼠标当前的位置实现方法
2016/10/27 Javascript
原生js实现简单的链式操作
2017/07/04 Javascript
jQuery发请求传输中文参数乱码问题的解决方案
2018/05/22 jQuery
前端防止用户重复提交js实现代码示例
2018/09/07 Javascript
JavaScript常用内置对象用法分析
2019/07/09 Javascript
JavaScript 实现自己的安卓手机自动化工具脚本(推荐)
2020/05/13 Javascript
你不知道的 TypeScript 高级类型(小结)
2020/08/28 Javascript
vue实现简单计算商品价格
2020/09/14 Javascript
[10:07]2014DOTA2国际邀请赛 实拍选手现场观战DK对阵Titan
2014/07/12 DOTA
下载糗事百科的内容_python版
2008/12/07 Python
Python fileinput模块使用实例
2015/05/28 Python
python入门教程 python入门神图一张
2018/03/05 Python
Python实现的质因式分解算法示例
2018/05/03 Python
python绘制评估优化算法性能的测试函数
2019/06/25 Python
我们为什么要减少Python中循环的使用
2019/07/10 Python
详解Python3中的 input() 函数
2020/03/18 Python
Saucony澳大利亚官网:美国跑鞋品牌,运动鞋中的劳斯莱斯
2018/05/05 全球购物
Java中的异常处理机制的简单原理和应用
2013/04/27 面试题
事业单位绩效考核实施方案
2014/03/27 职场文书
2014年大班保育员工作总结
2014/12/02 职场文书
2015年大学元旦晚会活动策划书
2014/12/09 职场文书
2015年度员工自我评价范文
2015/03/11 职场文书
欠款纠纷起诉状
2015/05/19 职场文书
钓鱼岛事件感想
2015/08/11 职场文书
Python获取字典中某个key的value
2022/04/13 Python
HTML5中的DOCUMENT.VISIBILITYSTATE属性详解
2023/05/07 HTML / CSS