谈谈Jquery ajax中success和complete有哪些不同点


Posted in Javascript onNovember 20, 2015

废话不多说了,先给大家贴一段代码看看吧,

$.ajax({
   type: "post",
   url: url,
   dataType:'html',
   success: function(data) { },
   complete: function(XMLHttpRequest, textStatus) { },
   error: function(){}
});

success : 当请求成功时调用的函数。这个函数会得到一个参数:从服务器返回的数据。当请求成功时调用函数,即status==200。

complete :当请求完成时调用的函数。这个函数会得到两个参数:XMLHttpRequest对象和一个描述请求成功的类型的字符串。当请求完成时调用函数,即status==404、403、302...。

所以,在写success或者complete的方法时,注意传入的参数,和使用传进来参数对象来解决我们的问题

参数列表:

参数名 类型 描述
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 }

好了,由于时间原因,本文先给大家介绍到这里,希望本文分享能够给大家带来灵感,帮助大家更好的学习javascript ajax success  complete相关知识。

Javascript 相关文章推荐
jquery.simple.tree插件 更简单,兼容性更好的无限树插件
Sep 03 Javascript
Jquery颜色选择器ColorPicker实现代码
Nov 14 Javascript
jQuery中fadeIn、fadeOut、fadeTo的使用方法(图片显示与隐藏)
May 08 Javascript
jQuery实现当按下回车键时绑定点击事件
Jan 28 Javascript
node.js中的fs.fstat方法使用说明
Dec 15 Javascript
JS实现网页游戏中滑块响应鼠标点击移动效果
Oct 19 Javascript
vue.js事件处理器是什么
Mar 20 Javascript
Three.js如何实现雾化效果示例代码
Sep 27 Javascript
js 提取某()特殊字符串长度的实例
Dec 06 Javascript
vue-router的使用方法及含参数的配置方法
Nov 13 Javascript
详解在vue-cli3.0中自定css、js和图片的打包路径
Aug 26 Javascript
微信小程序吸底区域适配iPhoneX的实现
Apr 09 Javascript
jQuery实现带玻璃流光质感的手风琴特效
Nov 20 #Javascript
JQuery.Ajax()的data参数类型实例详解
Nov 20 #Javascript
Jquery Ajax Error 调试错误的技巧
Nov 20 #Javascript
jQuery实现简单的文件上传进度条效果
Mar 26 #Javascript
jquery实现手风琴效果
Nov 20 #Javascript
不想让浏览器运行javascript脚本的方法
Nov 20 #Javascript
jquery背景跟随鼠标滑动导航
Nov 20 #Javascript
You might like
Excel数据导入Mysql数据库的实现代码
2008/06/05 PHP
分割GBK中文遭遇乱码的解决方法
2013/08/09 PHP
PHP中常用的三种设计模式详解【单例模式、工厂模式、观察者模式】
2019/06/14 PHP
Javascript中的数学函数集合
2007/05/08 Javascript
限制文本框输入N个字符的js代码
2010/05/13 Javascript
jQuery getJSON 处理json数据的代码
2010/07/26 Javascript
输入密码检测大写是否锁定js实现代码
2012/12/03 Javascript
flash调用js中的方法,让js传递变量给flash的办法及思路
2013/08/07 Javascript
浅谈jQuery中replace()方法
2015/05/13 Javascript
Ztree新增角色和编辑角色回显问题的解决
2016/10/25 Javascript
Javascript 普通函数和构造函数的区别
2016/11/05 Javascript
基于javascript实现的快速排序
2016/12/02 Javascript
Angularjs实现上传图片预览功能
2017/09/01 Javascript
vue.js单文件组件中非父子组件的传值实例
2018/09/13 Javascript
基于vue通用表单解决方案的思考与分析
2019/03/16 Javascript
js 动态校验开始结束时间的实现代码
2020/05/25 Javascript
使用Python获取CPU、内存和硬盘等windowns系统信息的2个例子
2014/04/15 Python
用于统计项目中代码总行数的Python脚本分享
2015/04/21 Python
Python简单连接MongoDB数据库的方法
2016/03/15 Python
Python中的is和==比较两个对象的两种方法
2017/09/06 Python
Python判断两个对象相等的原理
2017/12/12 Python
Python django使用多进程连接mysql错误的解决方法
2018/10/08 Python
css3实现画半圆弧线的示例代码
2017/11/06 HTML / CSS
39美元购买一副眼镜或太阳镜:39DollarGlasses.com
2018/06/17 全球购物
Android面试题附答案
2014/12/08 面试题
工程管理造价应届生求职信
2013/11/13 职场文书
财务方面个人工作的自我评价
2013/12/28 职场文书
经典促销广告词大全
2014/03/19 职场文书
社区网格化管理实施方案
2014/03/21 职场文书
《从现在开始》教学反思
2014/04/15 职场文书
2015届本科毕业生自我鉴定
2014/09/27 职场文书
校运动会广播稿300字
2014/10/07 职场文书
北京青年观后感
2015/06/15 职场文书
2015年学校教科室工作总结
2015/07/20 职场文书
创业计划书之养殖业
2019/10/11 职场文书
Redis 限流器
2022/05/15 Redis