0

我有一个应用程序,我需要从 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 还很陌生。

4

1 回答 1

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);
  });
});
于 2014-10-04T13:50:10.187 回答