首页 >

JavaScript 异步调用框架 (Part 4 – 链式调用)【javascript】

web前端|js教程JavaScript 异步调用框架 (Part 4 - 链式调用)【javascript】
JavaScript,异步调用,框架
web前端-js教程
现实开发中,要按顺序执行一系列的同步异步操作又是很常见的。还是用百度Hi网页版中的例子,我们先要异步获取联系人列表,然后再异步获取每一个联系人的具体信息,而且后者是分页获取的,每次请求发送10个联系人的名称然后取回对应的具体信息。这就是多个需要顺序执行的异步请求。
为此,我们需要设计一种新的操作方式来优化代码可读性,让顺序异步操作代码看起来和传统的顺序同步操作代码一样优雅。
传统做法
大多数程序员都能够很好的理解顺序执行的代码,例如这样子的:
gps车辆管理系统源码,vscode远程调试c项目,ubuntu 终端 软件,tomcat 如何下载, sqlite 内存,服饰品牌网页设计,php 数据库优化,企业服务器架构,jquery calendar插件,builive前端框架,ncep爬虫,php标题,监控网站seo,springboot类覆盖,dede php标签使用,网站文章字体大小,破解网页明文,网站空白模板下载,安装tag静态化插件 后台不能登陆,物流管理系统静态页面模板,网站管理系统破解版,求婚程序源码lzw
 
var firstResult = firstOperation(initialArgument);
var secondResult = secondOperation(firstResult);
var finalResult = thirdOperation(secondResult);
alert(finalResult);

其中先执行的函数为后执行的函数提供所需的数据。然而使用我们的异步调用框架后,同样的逻辑必须变成这样子:

交易软件源码,vscode如何打开压缩包,ubuntu命令行升级,tomcat进程存在吗,sqlite截位,网页设计制作 案例,网站租用服务器多少钱,中国市区地图插件,客服前端框架,卖车爬虫,免费php源码,河北省seo网络优化,springboot合作开发,数据分享下载网站有哪些,ajax获取网页源代码,html模板网,dede后台登录模版,h5页面实现购物车,c小区物业管理系统源码,程序端口 指定发送端口lzw
 
firstAsyncOperation(initialArgument).addCallback(function(firstResult) {
secondAsyncOperation(firstResult).addCallback(function(secondResult) {
thirdAsyncOperation(secondResult).addCallback(function(finalResult) {
alert(finalResult);
});
});
});

链式写法
我认为上面的代码实在是太不美观了,并且希望能够改造为jQuery风格的链式写法。为此,我们先构造一个用例:

ssh框架项目实例源码,vscode点击跳转页面,ubuntu环境搭建,导入tomcat源码,sqlite数据库建表,网页设计如何设置字体,asp 打开access数据库,香港服务器 托管 租用,wordpress灯箱插件,搭建前端框架的书名,起点网爬虫,php7 配置,凡科seo,springboot规范,e:loop 标签 参数,html网站模版下载,delphi获取网页源 软件,discuz模板 虚拟货币系统,html后台登录界面模板,wordpress 页面指向,迅易网络投票评选管理系统,比特币 交易程序lzw
 
Async.go(initialArgument)
.next(firstAsyncOperation)
.next(secondAsyncOperation)
.next(thirdAsyncOperation)
.next(function(finalResult) { alert(finalResult); })

在这个用例当中,我们在go传入初始化数据,然后每一个next后面传入一个数据处理函数,这些处理函数按顺序对数据进行处理。
同步并存
上面的用例调用到的全部都是异步函数,不过我们最好能够兼容同步函数,让使用者无需关心函数的具体实现,也能使用这项功能。为此我们再写一个这样的用例:

 
Async.go(0)
.next(function(i) { alert(i); return i + 1; })
.next(function(i) {
alert(i);
var operation = new Async.Operation();
setTimeout(function() { operation.yield(i + 1); }, 1000);
return operation;
})
.next(function(i) { alert(i); return i + 1; })
.next(function(i) { alert(i); return i; });

在上述用例中,我们期待能够看到0, 1, 2, 3的提示信息序列,并且1和2之间间隔为1000毫秒。
异步本质
一个链式调用,本质上也是一个异步调用,所以它返回的也是一个Operation实例。这个实例自然也有result、state和completed这几个字段,并且当整个链式调用完成时,result等于最后一个调用返回的结果,而completed自然是等于true。
我们可以扩展一下上一个用例,得到如下用例代码:

 
var chainOperation = Async.go(0)
.next(function(i) { alert(i); return i + 1; })
.next(function(i) {
alert(i);
var operation = new Async.Operation();
setTimeout(function() { operation.yield(i + 1); }, 1000);
return operation;
})
.next(function(i) { alert(i); return i + 1; })
.next(function(i) { alert(i); return i; });
setTiemout(function() { alert(chainOperation.result; }, 2000);

把链式调用的返回保存下来,在链式调用完成时,它的result应该与最后一个操作的返回一致。在上述用例中,也就是3。
调用时机
尽管我们提供了一种链式调用方式,但是用户不一定会按照这种固定的方式来调用,所以我们仍然要考虑兼容用户的各种可能用法,例如说异步地用next往调用链添加操作:

 
var chainOperation = Async.go(0);
chainOperation.next(function(i) { alert(i); return i + 1; });
setTimeout(function() {
chainOperation.next(function(i) {
alert(i);
var operation = new Async.Operation();
setTimeout(function() { operation.yield(i + 1); }, 2000);
return operation;
})
}, 1000);
setTimeout(function() {
chainOperation.next(function(i) { alert(i); return i + 1; });
}, 2000);

在这个用例当中,用户每隔1000毫秒添加一个操作,而其中第二个操作耗时2000毫秒。也就是说,添加第三个操作时第二个操作还没返回。作为一个健壮的框架,必须要能兼容这样的使用方式。
此外我们还要考虑,用户可能想要先构造调用链,然后再执行调用链。这时候用户就会先使用next方法添加操作,再使用go方法执行。

 
var chainOperation = Async
.chain(function(i) { alert(i); return i + 1; })
.next(function(i) {
alert(i);
var operation = new Async.Operation();
setTimeout(function() { operation.yield(i + 1); }, 2000);
return operation;
})
.go(0)
setTimeout(function() {
chainOperation.next(function(i) { alert(i); return i + 1; })
}, 1000);

在上述用例中,用户通过chain和next添加了头同步操作和异步操作各一个,然后用go执行调用链,在调用链执行完毕之前又用next异步追加了一个操作。一个健壮的框架,在这样的用例当中应该能够如同用户所期望的那样提示0, 1, 2。
小结
针对链式调用的需求,我们设计了如此多的用例,包括各种奇怪的异步调用方式。最终如何实现这样的功能呢?


JavaScript 异步调用框架 (Part 4 - 链式调用)【javascript】
  • PHP异步调用socket实现代码【PHP】
  • PHP异步调用socket实现代码【PHP】 | PHP异步调用socket实现代码【PHP】 ...

    JavaScript 异步调用框架 (Part 4 - 链式调用)【javascript】
  • python使用multiprocessing模块实现带回调函数的异步调用方法
  • python使用multiprocessing模块实现带回调函数的异步调用方法 | python使用multiprocessing模块实现带回调函数的异步调用方法 ...

    JavaScript 异步调用框架 (Part 4 - 链式调用)【javascript】
  • JavaScript 异步调用框架 (Part 5 - 链式实现)【javascript】
  • JavaScript 异步调用框架 (Part 5 - 链式实现)【javascript】 | JavaScript 异步调用框架 (Part 5 - 链式实现)【javascript】 ...