async 异步流程控制规则
github 学习async网址 : https://github.com/caolan/async/
1.Async 函数介绍
async 主要实现了三个部分的流程控制功能
1.集合:Collections
2.流程控制:Control Flow
3.工具类:Utils
1:集合 Collections
each 如果相对同一个集合中的所有元素都执行同一个异步操作
map 对集合中的每一个元素,执行某个异步操作,得到结果。所有结果将汇总到最终的callback 里 与 each 的区别是 ,each 只关心操作不管最后的值,而map 关心的时候最后产生的值
filter 使用异步操作 对集合的元素进行筛选,需要注意的是,iterator 与 callback只有一个参数,只能接收true 或 false
reject reject跟filter正好相反
reduce 可以给我们定一个初始值,用它与集合中的每一个元素做运算,最后得到一个值,reduce 从左向右来遍历元素,如果想从右向左,可以使用reduceRight
detect:用于取得集合中满足条件的第一个元素
concat:将多个异步操作的结果合并为一个数组
2.控制流程 Control Flow
series:串行执行,一个函数数组中的每个函数,每一个函数执行完成之后才能执行下一个函数。
parallel:并行执行多个函数,每个函数都是立即执行,不需要等待其它函数先执行,传给最终callback 的数组中的数据按照tasks 声明的顺序,而不是执行完成的顺序。
whilst:相当于while .但其中的异步调用将在完成后才会进行下一次循环
forever 无论条件循环执行 如果不出错 callback 永远不会被执行
waterfall 按顺序 一次执行一组函数,每个函数产生的值 都将传给下一个。
3.工具类 Utils
memoize : 让某一个函数在内存中缓存它的计算结果,对于相同的参数,只计算一次,下次就直接拿到只算好的结果。
unmemoize:让已经被缓存的函数,返回不缓存的函数引用
log:执行某异步函数,并记录它的返回值,日志输出
dir:与log类似,不同之处在于 会调用浏览器的console.dir()函数,显示为dom视图
noConflict 如果之前在全局定义了async 变量,当导入本async.js 时,会先把之前的async变量保存起来,然后覆盖它,仅仅用于浏览器端,在nodejs 中没有
==================================================================================
series 函数 串行执行
async.series({
one:function(callback) {
callback(null,'one');
},
two:function(callback) {
callback(null,'two');
},
three:function(callback){
callback(null,'three');
}
}, function(err, results) {
console.log("=======================");
console.log(results); //{ one: 'one', two: 'two', three: 'three' }
});
数组形式的例子:
async.series([
function(callback) {
callback(null,'one');
},
function(callback) {
callback(null,'two');
},
function(callback){
callback(null,'three');
}
], function(err, results) {
console.log("=======================");
console.log(results); //['one','two','three']
});
series 函数第一个参数可以是一个数组,也可以是一个json 对象
waterfall 函数 ,瀑布流
waterfall 是按照顺序执行,每个函数产生的值都将传给下一个函数
async.waterfall([
function(callback){
callback(null,'one','two');
},
function(arg1,arg2,callback){
callback(null,'three');
},
function(arg1,callback){
callback(null,'done');
},
],function(err,result){
console.log(result);//done
})
waterfall 的tasks 参
数(数组内的函数)只能是 数组类型的
当中途有函数出错,其err 直接传给callback,结果被丢弃,后面的函数不再执行
parallel(tasksm[callback])
paralle 函数是并行执行多个函数,每个函数都是立即执行,不需要等待其它函数先执行
传给最终callback的数组中数据按照tasks 中声明的顺序,而不是执行完的顺序,实例如下
async.parallel([
function(callback){
console.log("1111111",req.query.page);
if(req.query.page == 4){
callback(null,'one');
}else{
console.log("0000000000000000000");
callback(null);
}
},
function(callback){
callback(null,'two');
},
function(callback){
callback(null,'threee');
},
function(callback){
callback(null,'four');
}
],function(err,results){
console.log(results);
})
async 异步流程控制规则的更多相关文章
- nodejs进阶(7)—async异步流程控制
Async介绍 Async是一个流程控制工具包,提供了直接而强大的异步功能.基于Javascript为Node.js设计,同时也可以直接在浏览器中使用. Async提供了大约20个函数,包括常用的 m ...
- async异步流程控制
http://cnodejs.org/topic/54acfbb5ce87bace2444cbfb 先安装:G:\www\nodejs\one\models>npm install async ...
- async异步流程控制神器
async https://www.npmjs.com/package/async Async is a utility module which provides straight-forward, ...
- Nodejs中使用异步流程控制Async
首先,我们都知道,Node基于事件驱动的异步I/O架构,所谓异步就是非阻塞,说白了就是一个事件执行了,我不必等待它执行完成后我才能执行下一个事件.所以在Node环境中的模块基本都是异步的,上一篇说到我 ...
- node核心:异步流程控制
Node.js的异步是整个学习Node.js过程中重中之重. 1)异步流程控制学习重点 2)Api写法:Error-first Callback 和 EventEmitter 3)中流砥柱:Promi ...
- 【javascript】Promise/A+ 规范简单实现 异步流程控制思想
——基于es6:Promise/A+ 规范简单实现 异步流程控制思想 前言: nodejs强大的异步处理能力使得它在服务器端大放异彩,基于它的应用不断的增加,但是异步随之带来的嵌套.难以理解的代码让 ...
- 使用yield进行异步流程控制
现状 目前我们对异步回调的解决方案有这么几种:回调,deferred/promise和事件触发.回调的方式自不必说,需要硬编码调用,而且有可能会出现复杂的嵌套关系,造成"回调黑洞" ...
- js 异步流程控制之 avQ(avril.queue)
废话前言 写了多年的js,遇到过最蛋疼的事情莫过于callback hell, 相信大家也感同身受. 业界许多大大也为此提出了很多不错的解决方案,我所了解的主要有: 朴灵 event proxy, 简 ...
- 异步流程控制库GoWithTheFlow
异步流程控制库GoWithTheFlow 一个尾触发方式来控制异步流程的库, 有seq(顺序执行) par(同步执行) 两种方法 博客 http://notes.jetienne.com/2011/0 ...
随机推荐
- Matlab 图像预处理
%%%%%%%%%%%%%%%%% %%降采样 clear all im={}; %创建字典保存读取的图片 dis=dir('F:\kaggle_data_zip\Sample\*.jpeg');%% ...
- ubuntu apache svn 参考
Ubuntu下Subversion服务器的安装配置 本文涉及的范围 要通过 HTTP 协议访问 Subversion 文件仓库,需要安装并配置好 Web 服务器.Apache2 被证实可以很好 ...
- FJ省队集训DAY5 T1
思路:考试的时候打了LCT,自以为能过,没想到只能过80.. 考完一想:lct的做法点数是100W,就算是nlogn也会T. 讲一下lct的做法把:首先如果一条边连接的两个点都在同一个联通块内,那么这 ...
- Powershell使用管道
管道并不是什么新事物,以前的Cmd控制台也有重定向的命令,例如Dir | More可以将结果分屏显示.传统的Cmd管道是基于文本的,但是Powershell是基于对象. PS> ls | Sor ...
- ImageMagick提取图像原始数据(ImageData/RawData)
我用的是ImageMagickWand的接口,因为这接口比Core接口更上层,所以官方文档推荐用. 抽取整个图像文件字节数据: http://www.imagemagick.org/discourse ...
- win7系统如何恢复administrator用户
默认情况下,administrator用户是禁用的. 要恢复的话,右键单击我的电脑 管理-->本地用户和组-->用户-->右键属性 把"账户已禁用"前的选择符号去 ...
- MySql 查询表字段数
MySql 查询表字段数 SELECT COUNT(*) FROM information_schema.columns WHERE table_schema='test_cases' AND tab ...
- 贪心-hdu-1789-Doing Homework again
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1789 题目意思: 有n个作业,每个作业有一个截止日期,每个作业如果超过截止日期完成的时候有一个惩罚值 ...
- Windows下文件列举,搜索
Windows下列举文件用的函数是 FindFirstFile 和 FindNextFile ,另外一个结构体是WIN32_FIND_DATA 以下是MSDN对于WIN32_FIND_DATA的定义 ...
- git 学习笔记一
1.git的 介绍 分布式和 集中式 集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,可能提交一个10M的文件就需要5分钟, ...