jq中Deferred对象的使用
var d=$.Deferred();
//deferred下面的方法有:
// ["resolve", "resolveWith", "reject", "rejectWith", "notify", "notifyWith",
// "state", "always", "then", "promise", "pipe", "done", "fail", "progress"]
console.info(Object.keys(d));
console.info(d.pipe== d.then);//true
console.info(d.state());//初始化pending状态 //------------resolve对应的是done------------
function fn1(){
var def= $.Deferred();
setTimeout(function(){
def.resolve('成功了!');
},1000);
return def.promise();
}
fn1().done(function(data){
console.info(data);//成功了!
});
//或者可以这样写
fn1().then(function(data){ //then的参数为( fnDone, fnFail, fnProgress)
console.info(data);//成功了!
}); //------------reject对应的是fail------------
function fn2(){
var def= $.Deferred();
setTimeout(function(){
def.reject('失败了!');
},1000);
return def.promise();
}
fn2().fail(function(data){
console.info(data);//失败了!
});
//或者可以这样写
fn2().then(function(data){ //then的参数为( fnDone, fnFail, fnProgress)
//不会走
},function(data){
console.info(data);
}); //------------notify对应的是progress------------
function fn3(){
var def= $.Deferred();
setTimeout(function(){
def.notify('传递给下一步回调的通知!');
},1000);
return def.promise();
}
fn3().progress(function(data){
console.info(data);//传递给下一步回调的通知!
});
//或者可以这样写
fn3().then(function(data){ //then的参数为( fnDone, fnFail, fnProgress)
//不会走
},function(data){
//不会走
},function(data){
console.info(data);//传递给下一步回调的通知!
}); //------------always 不管成功与否都会执行回调------------
//deferred.done( arguments ).fail( arguments );
function fn4(){
var def= $.Deferred();
setTimeout(function(){
Math.random()>0.5?def.resolve('成功!'): def.reject('失败!')
},1000);
return def.promise();
}
fn4().always(function(data){
console.info(data);//成功!or失败!
}); //------------连续的回调依次执行------------
/*第一异步程序*/
function delayFn1(arg1){
var def= $.Deferred();
setTimeout(function(){
var data=arg1+1;
console.info("第一步--->",data);
def.resolve(data);
},1000);
return def.promise();
}
/*第二个异步程序*/
function delayFn2(arg2){
var def= $.Deferred();
setTimeout(function(){
var data=arg2+1;
def.resolve(data);
},1000);
return def.promise();
}
/*第三个异步程序*/
function delayFn3(arg3){
var def= $.Deferred();
setTimeout(function(){
var data=arg3+1;
def.resolve(data);
},1000);
return def.promise();
} delayFn1(1).then(function(data){
console.info("第二步--->",data);
return delayFn2(data)
}).then(function(data){
console.info("第三步--->",data);
return delayFn3(data)
}).then(function(data){
console.info("第四步--->",data);
alert(data);
})
jq中Deferred对象的使用的更多相关文章
- jQuery中deferred对象的使用(二)
接上一回的内容,漏了一个always()方法,参数也是回调函数,与done和fail不同的是,无论任何情况都执行always方法中的回调. deferred对象的使用(二) deferred对象不光可 ...
- jQuery中deferred对象的使用(一)
在jquery1.5之后的版本中,加入了一个deferred对象,也就是延迟对象,用来处理未来某一时间点发生的回调函数.同时,还改写了ajax方法,现在的ajax方法返回的是一个deferred对象. ...
- jQuery中异步操作对象Deferred
以下介绍一下jQuery中Deferred对象的使用: 1. 通过$.Deferred生成一个deferredObj对象; 2. deferredObj.done()指定操作成功时的回调函数; 3. ...
- javascript 学习笔记之JQuery中的Deferred对象
Deffered是Jquery中的一个非常重要的对象,从1.5版本之后,Jquery中的ajax操作都基于Deffered进行了重构,这个对象的处理模式就像其他Javascript框中的Promise ...
- JQ中的延迟对象deferred中的promise等的使用
一.什么是deferred对象? 开发网站的过程中,我们经常遇到某些耗时很长的javascript操作.其中,既有异步的操作(比如ajax读取服务器数据),也有同步的操作(比如遍历一个大型数组),它们 ...
- jQuery中的deferred对象和extend方法
1⃣️deferred对象 deferred对象是jQuery的回调函数解决方案,它是从jQuery1.5.0版本开始引入的功能 deferred对象的方法 (1) $.Deferred() 生成一个 ...
- jQuery中deferred的对象使用
什么是deferred对象 开发网站的过程中,我们经常遇到某些耗时很长的javascript操作.其中,既有异步的操作(比如ajax读取服务器数据),也有同步的操作(比如遍历一个大型数组),它们都不是 ...
- jquery中的 deferred之 deferred对象 (一)
案例: var def=$.Deferred(); console.log(def);//答案见 图1 图1: deferred就是一个有这些方法的对象. 看源码分析: Deferred: funct ...
- jq中的isArray方法分析,如何判断对象是否是数组
<!DOCTYPE html> <html> <head> <title>jq中的isArray方法分析</title> <meta ...
随机推荐
- How the Bitcoin protocol actually works
sklearn实战-乳腺癌细胞数据挖掘(博客主亲自录制视频教程) https://study.163.com/course/introduction.htm?courseId=1005269003&a ...
- linq总结系列(二)---Expression
一.linq中的表达式和表达式树 Linq中的表达式(Expression<TDel>)是强类型的lambda表达式,对Func和Action形式的委托做了一层封装. lambda表达式的 ...
- 1.springboot:入门程序
一.Spring Boot 简介 官网英文: Spring Boot makes it easy to create stand-alone, production-grade Spring base ...
- 20155332 2016-2017-2 《Java程序设计》第6周学习总结
20155332 2016-2017-2 <Java程序设计>第6周学习总结 教材学习内容总结 1.文件的读写 2.网络上传数据的基础 3.认识INputStream.OutputStre ...
- linux 网络之 bond 网卡模式
Linux bond模式通过多个网卡绑定技术既能增加服务器的可靠性,又增加了可用网络宽带,为用户提供不间断的网络服务: 七种bond模式: 第一种模式:mod=0 ,即:(balance-rr) Ro ...
- luogu P3565 [POI2014]HOT-Hotels
传送门 无脑暴力+O2=AC 题目要统计距离两两相等的三个点的组数,这三个点之间显然有一个点,并且这三个点到这个点的距离都相同.所以枚举中间这个点作为根,然后bfs整棵树,对于每一层,把以根的某个儿子 ...
- HDU2444 The Accomodation of Students【匈牙利算法】
题意: 有n个学生,有m对人是认识的,每一对认识的人能分到一间房,问能否把n个学生分成两部分,每部分内的学生互不认识,而两部分之间的学生认识.如果可以分成两部分,就算出房间最多需要多少间,否则就输出N ...
- 模板·点分治(luogu P3806)
[模板]洛谷·点分治 1.求树的重心 树的重心:若A点的子树中最大的子树的size[] 最小时,A为该树的中心 步骤: 所需变量:siz[x] 表示 x 的子树大小(含自己),msz[x] 表示 其子 ...
- D - Maximizing Advertising
题目链接:https://cn.vjudge.net/contest/250168#problem/D 题目大意:给你一些点的坐标,这些点属于两个帮派,让你将这些点分进两个不能重叠的矩形中,问你最多两 ...
- DSO windowed optimization 代码 (4)
5 "step"计算 参考<DSO windowed optimization 公式>,计算各个优化变量的增加量. 公式再写一下: \[\begin{align} \b ...