谈谈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 相关文章推荐
JavaScript 调试器简介
Feb 21 Javascript
三级下拉菜单的js实现代码
May 23 Javascript
js弹出层(jQuery插件形式附带reLoad功能)
Apr 12 Javascript
判断客户浏览器是否支持cookie的示例代码
Dec 23 Javascript
原生js制作简单的数字键盘
Apr 24 Javascript
Juery解决tablesorter中文排序和字符范围的方法
May 06 Javascript
jQuery 中的 DOM 操作
Apr 26 Javascript
jQuery页面加载初始化的3种方法(推荐)
Jun 02 Javascript
JavaScript中匿名函数的递归调用
Jan 22 Javascript
Vue框架中正确引入JS库的方法介绍
Jul 30 Javascript
JavaScript实现的原生态兼容IE6可调可控滚动文字功能详解
Sep 19 Javascript
jQuery简单实现根据日期计算星期几的方法
Jan 09 jQuery
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
php循环创建目录示例分享(php创建多级目录)
2014/03/04 PHP
ThinkPHP实现二级循环读取的方法
2014/11/03 PHP
php5.4以上版本GBK编码下htmlspecialchars输出为空问题解决方法汇总
2015/04/03 PHP
php基于双向循环队列实现历史记录的前进后退等功能
2015/08/08 PHP
PHP判断是否是微信打开还是浏览器打开的方法
2019/02/27 PHP
PHP学习记录之常用的魔术常量详解
2019/12/12 PHP
用htc组件制作windows选项卡
2007/01/13 Javascript
javascript读取RSS数据
2007/01/20 Javascript
如何快速的呈现我们的网页的技巧整理
2007/07/01 Javascript
jQuery 定时局部刷新(setInterval)
2010/11/19 Javascript
浅谈jQuery异步对象(XMLHttpRequest)
2014/11/17 Javascript
node.js中的events.emitter.once方法使用说明
2014/12/10 Javascript
浅谈javascript中字符串String与数组Array
2014/12/31 Javascript
javascript实现全局匹配并替换的方法
2015/04/27 Javascript
详解AngularJS中的表格使用
2015/06/16 Javascript
JS特效实现图片自动播放并可控的效果
2015/07/31 Javascript
手机端 HTML5使用photoswipe.js仿微信朋友圈图片放大效果
2016/08/25 Javascript
解析如何利用iframe标签以及js制作时钟
2016/12/08 Javascript
使用vue.js实现联动效果的示例代码
2017/01/10 Javascript
Angular 2父子组件数据传递之@Input和@Output详解 (上)
2017/07/05 Javascript
详解jQuery中关于Ajax的几个常用的函数
2017/07/17 jQuery
浅谈Node.js 子进程与应用场景
2018/01/24 Javascript
vue动画打包后失效问题的解决方法
2018/09/18 Javascript
vue中,在本地缓存中读写数据的方法
2018/09/21 Javascript
微信小程序学习笔记之目录结构、基本配置图文详解
2019/03/28 Javascript
Javascript三种字符串连接方式及性能比较
2019/05/28 Javascript
JavaScript遍历数组和对象的元素简单操作示例
2019/07/09 Javascript
python的urllib模块显示下载进度示例
2014/01/17 Python
Python实现的简单hangman游戏实例
2015/06/28 Python
Python实现多线程HTTP下载器示例
2017/02/11 Python
Python中表达式x += y和x = x+y 的区别详解
2017/06/20 Python
Python 中判断列表是否为空的方法
2019/11/24 Python
TensorFlow实现保存训练模型为pd文件并恢复
2020/02/06 Python
UNIX文件名称有什么规定
2013/03/25 面试题
退休教师欢送会致辞
2015/07/31 职场文书
Redis如何一键部署脚本
2021/04/12 Redis