首页 > 解决方案 > 怎么把`db.db.collection`返回的内容放到`res.json()`里面?

问题描述

在控制器中,它会搜索countries所有国家/地区的集合。里面db.db.collection ....我有console.log (countries)。它之所以有效,是因为终端将所有国家/地区都返回给我。但res.json (countries)不起作用。在客户端,它返回给我data: ''。如何将 in 返回的内容return countries放入res.json()

//控制器/国家

module.exports.read = (req, res) => {     
    const countries = db.db.collection('countries').findOne({}, function (findErr, countries) {
        if (findErr) throw findErr;
        console.log(countries); //it works, in terminal return me all countries

        return countries;
        });

    res.json(countries);
};

标签: javascriptnode.jsmongodbexpress

解决方案


这是在异步函数完成之前调用 return 的典型情况。很多人都搞错了。您需要在 db find 的回调中调用“返回”回调:

module.exports.read = (req, res) => {     
  db.db.collection('countries').findOne({}, function (findErr, countries) {
    if (findErr) throw findErr;
    console.log(countries); //it works, in terminal return me all countries
    res.json(countries);
  });
};

推荐阅读