如何在MongoDB上获取函数值collection.find()

时间:2014-11-21 09:25:42

标签: node.js mongodb express callback

当我在MongoDB / Node / Express中运行collection.find()时,我需要像这样返回我的数组的值,但是我会在回调地狱中返回;

foursquare.getVenues(params,function(error, venues) {
    if (!error) {
      var places = [];
      venues.response.venues.forEach(function(e) {
        places.push(
          {
          obj_id:e.id,
          name:e.name,
          distance:e.distance,
          here_now:req.collection.findById(e.id) //count- i want need this value
          }
        );
      });
      res.send(places);
    }
  });

1 个答案:

答案 0 :(得分:1)

您可以尝试使用Async https://github.com/caolan/async#each

var async = require('async');
...
foursquare.getVenues(params, function (error, venues) {
    if (!error) {
        throw err;
    }

    var places = [];
    async.each(venues.response.venues, function (e, callback) {
        db.collection.findById(e.id, function (err, res) {
            places.push({
                    obj_id: e.id,
                    name: e.name,
                    distance: e.distance,
                    here_now: res
                });
            callback()
        });
    }, function (err) {
        if (err) {
            console.log('A file failed to process');
        } else {
            console.log('All files have been processed successfully');
            res.send(places);
        }
    });
});

或使用async.map

var async = require('async');

var createArray = function (e, cb) {
    db.collection.findById(e.id,function(err,res){
        var obj = {
            obj_id: e.id,
            name: e.name,
            distance: e.distance,
            here_now: res
        }
        cb(null, obj);
    });
}


async.map(venues.response.venues, createArray, function (err, places) {
    if(err){
        throw err;
    }
    console.log(places);
});