jquery Deferred 快速解决异步回调的问题
作者:bea
jquery Deferred 快速解决异步回调的问题 function ok(name){ var dfd = new $.Deferred(); callback:func(){ return dfd.resolve( response ); } return dfd.promise();}$.when(ok(1),ok(2)).then(function(resp1,resp2){}) //相关API 分成3类 1类:$.when(pro1,pro
jquery Deferred 快速解决异步回调的问题
function ok(name){
var dfd = new $.Deferred();
callback:func(){
return dfd.resolve( response );
}
return dfd.promise();
}
$.when(ok(1),ok(2)).then(function(resp1,resp2){})
//相关API 分成3类
1类:$.when(pro1,pro1) 将多个 promise 对象以and的关系 合并为1个
2类:promise 激发为 解决 deferred.resolve([ args ] ) deferred.resolveWith( context, [ args ] )
和 拒绝 .reject .rejectWith
context 上下文 替换 this 和通知 .notify .notifyWith
3类: 对激发的响应 解决时deferred.done(args) 拒绝时 deferred.fail() 通知时 deferred.progress()
不管 解决 或 拒绝 deferred.always()
deferred.then( doneCallbacks, failCallbacks [, progressCallbacks] )
promise(或者叫deferred 延迟对象如何获取?)
var dfd = new $.Deferred(); return dfd.promise();
返回promise当前状态
deferred.state() pending(尚未完成) resolved rejected
管道
deferred.pipe( [ doneFilter ], [ failFilter ] )
var defer = $.Deferred()
var filtered = defer.pipe( null, function( value ) {
return value * 3;
});
defer.reject( 6 );
filtered.fail(function( value ) {
alert( "Value is ( 3*6 = ) 18: " + value );
});
以上这篇jquery Deferred 快速解决异步回调的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
猜你喜欢
您可能感兴趣的文章:
- jQuery子窗体取得父窗体元素的方法
- js控制div弹出层实现方法
- JavaScript实现点击文字切换登录窗口的方法
- jQuery实现仿腾讯微博滑出效果报告每日天气的方法
- JS选项卡动态替换banner图片路径的方法
- js操作css属性实现div层展开关闭效果的方法
- javascript中this的四种用法
- JQuery插件jcarousellite的参数中文说明
- javascript实现炫酷的拖动分页
- JS+CSS实现的拖动分页效果实例
- 浅谈jQuery构造函数分析
- 在JavaScript中正确引用bind方法的应用
- jQuery实现页面内锚点平滑跳转特效的方法总结
- javascript实现验证IP地址等相关信息代码
- 招聘网站基于jQuery实现自动刷新简历
- javascript实现获取字符串hash值
- 关于JS中的apply,call,bind的深入解析
- javascript中apply、call和bind的使用区别
- JavaScript数组去重的两种方法推荐