zoukankan      html  css  js  c++  java
  • nodejs Async 使用方法(解决多层回调嵌套)

    由于nodejs是异步处理的,有时我们想同步从mysql里取出数据,最后在处理逻辑 就需要用到此扩展;

    此扩展可以避免多层回调;

    安装方法:

    npm install async

    使用方法:

    1、parallel 多个函数并行执行 

     1 var Async = require('async');
     2 
     3 Async.parallel(
     4     [
     5         function(callback){
     6             // 此处查询数据库代码
     7             DaoUser.getUserByID(userId, function(err, user) {
     8                 callback(err, user);
     9             });
    10         },
    11         function(callback){
    12             // 此处查询数据库代码
    13             DaoUser.getTotal(callback, function(err, count){
    14                 callback(err, count);
    15             });
    16         }
    17         // 如果还需要查询数据 继续添加方法即可
    18     ],
    19     function(err, results){
    20         var user = results[0];
    21         var count = results[1];
    22     }
    23 );

    2、waterfall 多个方法依次执行,前一个函数的返回值可以传递给下一个函数

     1 var Async = require('async');
     2 
     3 Async.waterfall([
     4     function(callback) {
     5         DaoUser.getUserIdByName(uName, function(err, userId) {
     6             callback(null, userId);
     7         });
     8     },
     9     function(userId, callback) {
    10         DaoTask.getDateByUid(userId, function(err, tasks) {
    11             callback(null, tasks);
    12         });
    13     }
    14 ], function(err, result) {
    15     var tasks = result;
    16 });

     3、map 遍历数组的值,执行结果传给最后的callback

    var Async = require('async');
    
    
    var array = [1,2,3,4];
    Async.map(array,
        function(data, callback) {
            data ++;
            callback(null, data);
        },
        function(err, results) {
            console.log(results);
        }
    );
    // 结果 [ 2, 3, 4, 5 ]

      

  • 相关阅读:
    JSP XML数据处理
    JSP 连接数据库
    JSP 发送邮件
    IDEA新建maven项目没有webapp目录解决方法
    web项目中idea控制台中文乱码的解决方法
    Spring基础-12-基于xml配置的事务
    Spring基础-11-事务细节
    Spring基础-10-源码分析
    Spring基础-09-事务
    Spring基础-08-jdbcTemplate
  • 原文地址:https://www.cnblogs.com/gouge/p/7097880.html
Copyright © 2011-2022 走看看