详解jQuery中的deferred对象的使用(一)


Posted in Javascript onMay 27, 2016

 deferred对象是jQuery对Promises接口的实现。它是非同步操作的通用接口,可以被看作是一个等待完成的任务,开发者通过一些通过的接口对其进行设置。事实上,它扮演代理人(proxy)的角色,将那些非同步操作包装成具有某些统一特性的对象,典型例子就是Ajax操作、网页动画、web worker等等。

jQuery的所有Ajax操作函数,默认返回的就是一个deferred对象。

在jquery1.5之后的版本中,加入了一个deferred对象,也就是延迟对象,用来处理未来某一时间点发生的回调函数。同时,还改写了ajax方法,现在的ajax方法返回的是一个deferred对象。

那就来看看deferred对象的用法。

1.ajax的链式回调

// ajax方法返回的是一个deferred对象,可以直接使用链式写法
$.ajax('test.json').done(function(resp){
// done 相当于success回调,其中默认的参数为success回调的参数
alert('success');
}).fail(function(){
// fail 相当于error回调
alert('error');
});

还可以同时写多个回调,会按照顺序依次执行

$.ajax('test.json').done(function(resp){
// done 相当于success回调,其中默认的参数为success回调的参数
alert('success');
}).done(function(){
// do something...
}).done(function(){
// do something...
});

deferred对象还有一个then方法,其实它是一个整合done和fail的方法,它接受一到两个参数,如果有两个参数,那么第一个就是done方法的回调函数,第二个是fail方法的回调函数。如果只有一个参数,那就是done方法的回调函数。

var success = function(){
alert('success'); 
};
var error = function(){
alert('error');
};
// 两个参数
$.ajax('test.json').then(success, error);
// 一个参数
$.ajax('test.json').then(success);

jQuery还提供了一个$.when(deferreds)的方法来执行一个或多个延迟对象的回调函数,当它的参数是延迟对象时,它会在所有延迟对象代表的异步执行完后再执行相应的回调函数

$.when($.ajax('test.json'), $.ajax('demo.json')) .done(function(){
alert('success'); 
}).fail(function(){
alert('error');
});

很好理解,只有当所有异步都成功时,才会执行done方法中的回调,否则会执行fail方法中的回调,同样好理解的是的done方法中回调函数的默认参数数量则和when方法参数数量相同。

而如果when方法中传入的只是普通对象,不是deferred对象时,会立即执行done方法中的回调,回调函数的默认参数为传入when方法的对象本身。

// 当传入when方法的参数只是普通对象时
$.when({test: 'test'}).done(function(resp){
console.log(resp.test); // 'test' 
}).fail(function(){
// 由于传入的对象不是deferred对象,那么就不会调用fail中的回调了 
})

当你需要两个甚至更多的异步结束后才调用回调函数,同时这些异步ajax可能还需要修改传输方式type或者传数据data时,代码就显得很乱,可读性很差。

所以就可以对ajax进行再次封装,提高代码可读性

var ajax = function(url, type, param){
return $.ajax({
url: url,
type: type,
data: param || {} 
}); 
};
ajax('test.json').done(function(resp){
alert('success');
}).fail(function(){
alert('error');
});

以上所述是小编给大家介绍的jQuery中的deferred对象的使用(一)的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
基于jquery的划词搜索实现(备忘)
Sep 14 Javascript
jQuery事件用法实例汇总
Aug 29 Javascript
JavaScript中的对象序列化介绍
Dec 30 Javascript
基于JavaScript如何实现私有成员的语法特征及私有成员的实现方式
Oct 28 Javascript
Angular路由简单学习
Dec 26 Javascript
JS使用cookie实现只出现一次的广告代码效果
Apr 22 Javascript
JavaScript高阶函数_动力节点Java学院整理
Jun 28 Javascript
JavaScript实现的原生态兼容IE6可调可控滚动文字功能详解
Sep 19 Javascript
100行代码实现vue表单校验功能(小白自编)
Nov 19 Javascript
node.js使用http模块创建服务器和客户端完整示例
Feb 10 Javascript
vue 路由懒加载中给 Webpack Chunks 命名的方法
Apr 24 Javascript
jQuery+ThinkPHP实现图片上传
Jul 23 jQuery
基于JS实现密码框(password)中显示文字提示功能代码
May 27 #Javascript
使用jQuery制作Web页面遮罩层插件的实例教程
May 26 #Javascript
Node.js的npm包管理器基础使用教程
May 26 #Javascript
JavaScript中的各种操作符使用总结
May 26 #Javascript
浅析JavaScript中的对象类型Object
May 26 #Javascript
简单总结JavaScript中的String字符串类型
May 26 #Javascript
BootStrap中Datetimepicker和uploadify插件应用实例小结
May 26 #Javascript
You might like
MOTOROLA 摩托罗拉 MODEL 66-XI五灯中波收音机
2021/03/02 无线电
简单的页面缓冲技术
2006/10/09 PHP
轻松修复Discuz!数据库
2008/05/03 PHP
phpexcel导入excel数据使用方法实例
2013/12/24 PHP
PHP实现冒泡排序的简单实例
2016/05/26 PHP
tp5(thinkPHP5)框架数据库Db增删改查常见操作总结
2019/01/10 PHP
alixixi runcode.asp的代码不错的应用
2007/08/08 Javascript
Jquery搜索父元素操作方法
2015/02/10 Javascript
JavaScript实现表格点击排序的方法
2015/05/11 Javascript
在JavaScript应用中实现延迟加载的方法
2015/06/25 Javascript
jquery实现两个图片渐变切换效果的方法
2015/06/25 Javascript
关于JS中match() 和 exec() 返回值和属性的测试
2016/03/21 Javascript
JavaScript微信定位功能实现方法
2016/11/29 Javascript
JavaScript正则表达式替换字符串中图片地址(img src)的方法
2017/01/13 Javascript
JavaScript中清空数组的三种方式
2017/03/22 Javascript
javascript 初学教程及五子棋小程序的简单实现
2017/07/04 Javascript
详谈js模块化规范
2017/07/07 Javascript
vue webpack打包优化操作技巧
2018/02/22 Javascript
[50:44]DOTA2-DPC中国联赛 正赛 SAG vs Dragon BO3 第二场 2月22日
2021/03/11 DOTA
python 实现归并排序算法
2012/06/05 Python
深入浅析ImageMagick命令执行漏洞
2016/10/11 Python
Python函数式编程指南:对生成器全面讲解
2019/11/19 Python
Python之——生成动态路由轨迹图的实例
2019/11/22 Python
2020新版本pycharm+anaconda+opencv+pyqt环境配置学习笔记,亲测可用
2020/03/24 Python
python3.6.5基于kerberos认证的hive和hdfs连接调用方式
2020/06/06 Python
C++和python实现阿姆斯特朗数字查找实例代码
2020/12/07 Python
NARS化妆品官方商店:美国彩妆品牌
2017/08/26 全球购物
英国鲜花速递:Serenata Flowers
2018/04/03 全球购物
Johnson Fitness澳大利亚:高级健身器材
2021/03/16 全球购物
出口公司经理求职简历中的自我评价
2013/10/13 职场文书
高考自主招生自荐信
2013/10/20 职场文书
化学系大学生自荐信范文
2014/03/01 职场文书
公路施工安全责任书
2015/05/08 职场文书
阿甘正传观后感
2015/06/01 职场文书
SQL实战演练之网上商城数据库商品类别数据操作
2021/10/24 MySQL
MySQL数据库查询之多表查询总结
2022/08/05 MySQL