博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
jquery Deferred 对象应用实例
阅读量:4706 次
发布时间:2019-06-10

本文共 1073 字,大约阅读时间需要 3 分钟。

不了解jquery deferred对象的先google一下“javascript promise模式”和“jquery deferred对象”。搜到的几篇都讲得比较详细了。一下只列出常见的用途。

1.我有两个异步操作f1和f2,f2需要依赖f1异步返回的结果,不写成回调,如何做?

先考虑我希望写成的样子:

//f3用来确定f2返回的结果 f1().pipe(f2).then(f3);

  再看f1和f2实现就很简单了:

var f1 = function(){        var _i = $.Deferred();        setTimeout(function(){            _i.resolve("f1的返回结果");        },1000);                return _i;    }var f2 = function(data){    var _i = $.Deferred();    console.log( data);    setTimeout(function(){            _i.resolve("f2的返回结果");    },1000);    return _i;}var f3 = function( data ){    console.log( data );}

 

2.我有f1和f2两个一步操作,不互相依赖,但是希望在两者都完成后再执行操作f3,如何做?

  以下直接抄自jquery 手册

$.when($.ajax("/page1.php"), $.ajax("/page2.php")).done(function(a1,  a2){    //a1和a2分别是两个ajax的返回结果   var jqXHR = a1[2]; /* arguments are [ "success", statusText, jqXHR ] */   if ( /Whip It/.test(jqXHR.responseText) ) {      alert("First page has 'Whip It' somewhere.");   }});

3.deferred对象还有个有意思的notify对象。这个方法可以再resolve和reject之前通知progress callback来进行相应的操作。

转载于:https://www.cnblogs.com/sskyy/archive/2012/06/14/2548839.html

你可能感兴趣的文章
Error和Exception
查看>>
Python和Singleton (单件)模式[转载]
查看>>
httpclient设置proxy与proxyselector
查看>>
IT常用单词
查看>>
拓扑排序
查看>>
NYOJ--32--SEARCH--组合数
查看>>
gulpfile 压缩模板
查看>>
【34.14%】【BZOJ 3110】 [Zjoi2013]K大数查询
查看>>
【 henuacm2016级暑期训练-动态规划专题 A 】Cards
查看>>
第五篇:白话tornado源码之褪去模板的外衣
查看>>
设备常用框架framework
查看>>
bootstrap模态框和select2合用时input无法获取焦点(转)
查看>>
MockObject
查看>>
BZOJ4516: [Sdoi2016]生成魔咒(后缀自动机)
查看>>
查看手机已经记住的WIFI密码
查看>>
最新版IntelliJ IDEA2019 破解教程(2019.08.07-情人节更新)
查看>>
C# 两个datatable中的数据快速比较返回交集或差集
查看>>
关于oracle样例数据库emp、dept、salgrade的mysql脚本复杂查询分析
查看>>
adb shell am 的用法
查看>>
iOS10 UI教程视图和子视图的可见性
查看>>