将多个对象传递给车把模板 - MongoDB,node.js,mongoskin

时间:2014-10-04 13:42:37

标签: javascript node.js mongodb mongoskin

我有一个应用程序,我需要从Mongo数据库中的两个不同的集合中读取并将返回的对象传递给一个把手模板。

使用下面的代码,我无法弄清楚如何让它工作,因为universityData和courseData变量没有填充,不知道这是否是正确的方法。

回调中的大学和课程对象正常工作,因为当我记录时,我得到了我需要的值。

router.get('/newcastle/G400', function(req, res) {
var db = req.db;
var universityData;
var courseData;

db.collection('universities', function(err, collection) {
    collection.findOne({'code': 'N21'}, function(err, university) {
        universityData = university;
        console.log(university);
        //res.render('course', {title: university.name, university: university, course: { "code": "G400", "name": "Computer Science", "studylength": "3 years (BSc)/4 years (MSc)", "requirements": "AAB - ABB", "satisfactionrating": "98"}});
    });
});
db.collection('courses', function(err, collection) {
    collection.findOne({'universitycode': 'N21', 'code': 'G400'}, function(err, course) {
        courseData = course;
        console.log(course);
    });
});
console.log(universityData);
console.log(courseData);
res.render('course', {university: universityData, course: courseData});
});

我的问题是如何将每个查询中的对象传递到一个模板中?

任何帮助都会受到赞赏,因为我对Javascript,node和Mongo都很新。

1 个答案:

答案 0 :(得分:1)

即使只是"两个"函数,您可以使用像async这样的模块来帮助组织它们而不需要深度嵌套。例如:

var async = require('async');

// ...

router.get('/newcastle/G400', function(req, res) {
  var db = req.db;

  async.parallel([
    universityData: function(callback) {
      db.collection('universities', function(err, collection) {
        if (err)
          return callback(err);
        collection.findOne({'code': 'N21'}, callback);
      });
    },
    courseData: function(callback) {
      db.collection('courses', function(err, collection) {
        if (err)
          return callback(err);
        collection.findOne({'universitycode': 'N21', 'code': 'G400'}, callback);
      });
    }
  ], function(err, results) {
    if (err)
      return res.send(500);
    // results === { universityData: { ... }, courseData: { ... } }
    res.render('course', results);
  });
});