资料

GITHUB async

ASYNC详解—from csdn

nodejs的高性能与灵活性让服务端开发变得有了些乐趣,最近在看nodejs在服务端的一些应用,觉得其npm下的众多开源包让其虽没有大型的框架 却能更自由的引用外部的模块编写属于自己风格的代码架构。

学习过程中,最让人觉得头痛的地方,个人觉得是异步执行,习惯了顺序执行代码的开发过程,开始的时候,因为面向对象的思想,封装继承多态的理论已经深入各编程语言,所以在进行设计的时候,好好的跌了一个跟头,发现原本清晰的业务逻辑,在执行后变得换乱不堪,其原因多在代码没有按照我的顺序或逻辑在执行。

后来才知道,原来上面遇到的问题是所有学习js的人都会经过的“名坑”,解决的方法也有很多。

其中最简单的一种就要属回调函数了,在js中,方法可以作为参数传递是其比较有趣的一个地方,而js中的异步执行造成 方法间的数据传递很不方便,需要借助回调函数的方式才能使用,但在回调函数以外,如果想用到这个数据,就要等这个方法执行完毕,而调用代码执行的时候,可能数据赋值的代码还未执行完,造成取不到值。

简单的回调函数 虽然解决了代码顺序执行的问题,但接下来,问题又来了,那就是回调函数之间,是嵌套的,深度的逻辑嵌套才能造成回调函数的正确执行逻辑和拿到我们想要拿到的数据,虽然在写回调函数加上注释的时候,个人觉得代码是更加流畅和可靠的,但在其可读性和代码量上 又是一个新的挑战。业务流程逐渐的加多,数据间的关系逐渐复杂时,业务之间的代码块变得越来越庞大和不易维护,相同作用的代码写了一遍又一遍,数据的传递也越发的困难和混乱。

试过了node中的很多种流程控制的方法,最舒服的就该属async了。

引用async模块,可以很好的实现代码的控制,保持代码的美观,其他的方法就不介绍了,在这里介绍一个auto方法,通过定义的function参数 、回调函数和数据结果集、方法间的相互依赖关系 可以很轻松的制定出代码规范的业务流程,使自己的业务逻辑既可以顺序执行,又对一些不必顺序执行的部分实施异步执行。

var async = require('async');

var funclist = {
func1: function (callback, results) {
console.log('func1执行,传入值{name:123}')
callback(null, {name:'123'});
},
func2: function (callback, results) {
console.log('func2执行,传入值 { "puncha": "during" }')
//console.log(results);
callback(null, { "puncha": "during" }); },
func3: ["func2", function (results, callback) {
console.log('func3在func2执行后执行,传入值 3')
// console.log(results);
callback(null, 3);
}],
func4: ["func3", function (results,callback) {
console.log('func4在func3执行后执行,总体执行结果为:')
console.log(results);
callback(null);
}]
}; async.auto(funclist);

以上代码执行结果为:

func1执行,传入值{name:123}
func2执行,传入值 { "puncha": "during" }
func3在func2执行后执行,传入值 3
func4在func1执行后执行(根据以上逻辑,执行顺序为 func1先执行,func2,4并行,func3最后执行 ),总体执行结果为:
{ func1: { name: '123' }, func2: { puncha: 'during' }, func3: 3 }

node.async.auto的更多相关文章

  1. node async基础1

    async的基础使用 1 async each   语法格式each(collection, iteratee, [callback])   用途:遍历集合中的元素,并行对每个元素执行一定的操作,但是 ...

  2. Node async 控制代码执行顺序

    当你有一个集合,你想循环集合,然后对每个集合按照顺序执行相应的方法你可以使用forEachSeries

  3. Node.js中Async详解:流程控制

    安装 npm install async --save 地址 https://github.com/caolan/async Async的内容主要分为三部分 流程控制: 简化九种常见的流程的处理 集合 ...

  4. Node.js——Async

    一:流程控制 为了适应异步编程,减少回调的嵌套,我尝试了很多库.最终觉得还是async最靠谱. 地址:https://github.com/caolan/async Async的内容分为三部分: 流程 ...

  5. node.js async 几个函数

    async.waterfallasync.seriesasync.parallelasync.auto http://my.oschina.net/huangsz/blog/176203http:// ...

  6. async 珠峰培训node正式课笔记 【async】任务流程控制,异步流程控制

    var async = require('async'); // series 串形任务 console.time('cost') async.series({ two:function(callba ...

  7. node的async模块

    废话不多说,直接开始 这个模块有几种方法.分别用于的不通的情况自己喜欢怎么用就怎么用 第一个方法,series  这个方法用于串行切无关联.什么意思那就是,里面的方法是一个一个执行的,每一个方法相互不 ...

  8. async源码学习 - 全部源码

    因为工作需要,可能我离前端走远了,偏node方向了.所以异步编程的需求很多,于是乎,不得不带着学习async了. 我有个习惯,用别人的东西之前,喜欢稍微搞明白点,so就带着看看其源码. github: ...

  9. Async 异步转同步详细流程解释

      安装 npm install async --save 地址 https://github.com/caolan/async Async的内容主要分为三部分 流程控制: 简化九种常见的流程的处理 ...

随机推荐

  1. Permutation Sequence 解答

    Question The set [1,2,3,…,n] contains a total of n! unique permutations. By listing and labeling all ...

  2. 【Android】使用FrameLayout布局实现霓虹灯效果

    FrameLayout是五大布局中最简单的一个布局. 在这个布局中,整个界面被当成一块空白备用区域,所有的子元素都不能被指定放置的位置. 它们统统放于这块区域的左上角,并且后面的子元素直接覆盖在前面的 ...

  3. 【二分答案】【POJ3122】【Northwestern Europe 2006】Pie

    Pie Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10629   Accepted: 3744   Special Ju ...

  4. 第二章实例:动态生成View控件例子---小球跟随手指滑动

    package mydefault.packge; import android.app.Activity; import android.content.Context; import androi ...

  5. Oracle闪回详解

      1.问题定义 闪回是dba做的工作.现在也可授权给某个用户. 闪回的定义:就是将用户错误的操作回恢到以前的状态.即使你的事务提交的commit. 如果你删除了一个表.Drop table(DDL) ...

  6. OA、CRM、ERP之间的区别和联系是什么?

    我们假设你是某机械行业的销售,一切从今天你收到公司的邮件,去上海参加展会开始 因为 去展会 所有 首先 你打开 OA 登陆 填写出差申请表 送交主管审批 填表--审批--行政订票酒店 然后呢 你飞去上 ...

  7. HDU 1046 - Gridland

    果然是数学题 #include <iostream> #include <cstdio> #include <cmath> using namespace std; ...

  8. C++标准程序库读书笔记-第二章新的语言特性

    1.基本类型的显式初始化 如果采用不含参数.明确的constructor(构造函数)调用语法,基本型别会被初始化为零: int i1; //undefined value int i2 = int() ...

  9. go import

    import "fmt"最常用的一种形式 import "./test"导入同一目录下test包中的内容 import f "fmt"导入f ...

  10. AngularJS中如何使用trigger报错$digest already in progress

    今天在使用trigger事件碰到问题: 例如我有两个按钮,button1和button2,在button2绑定了ng-click事件,现在想点击button1从而触发button2的ng-click事 ...