资料

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. UESTC_Sea Base Exploration CDOJ 409

    When the scientists explore the sea base, they use a kind of auto mobile robot, which has the missio ...

  2. HDU3994(Folyd + 期望概率)

    Mission Impossible Time Limit: 30000/10000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Oth ...

  3. python手记(44)

    #!/usr/bin/env python # -*- coding: utf-8 -*- #http://blog.csdn.net/myhaspl #code:myhaspl@qq.com imp ...

  4. laravel5.3 笔记一

    laravel5.3 笔记 安装环境 laravel环境,laravel中文学习论坛上面有相关的教程 创建应用 laravel new blog 其中blog就是你的应用的名字 数据迁移 php ar ...

  5. IOS 从Resource文件夹下Copy文件到沙盒

    - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. self.t ...

  6. 使用公用表表达式(CTE)

    本文来自:http://blog.csdn.net/songjie521/article/details/3321030 通用表表达式(CTEs)是SQL Server 2005的一项新功能.它们类似 ...

  7. H5单页面架构:backbone + requirejs + zepto + underscore

    首先,来看看整个项目结构. 跟上一篇angular类似,libs里多了underscore和zepto.三个根目录文件: index.html:唯一的html main.js:requirejs的配置 ...

  8. Mac神器Iterm2的Shell Integration的用法和注意事项

    在iterm2 v3.0版本中有了个新的feature——Shell Integration,其中比较重要的功能就是可以取代传统的“rz”.“sz”(即:向服务器上传.下载文件) 具体的用法可以参见官 ...

  9. 反射操作辅助类ReflectionUtil

    这篇文章的目的是介绍这样一种方式,就是在写一个函数的时候,传递的参数是object类型的,在这个函数里面想访问这个参数对象的某一属性值,我们知道这个属性值的name,但是一般情况下,object对象是 ...

  10. 实现android4.4新特性:沉浸式状态栏

    先放效果图: 所谓沉浸式状态栏,就是android4.4以后新加入的ui效果,能使最顶部的状态栏自动适宜app顶部的颜色,使两者看起来更像融为一体.下面放上实现代码: requestWindowFea ...