我在node.js中有一个模块,它通过sequelize lib与postgres数据库连接。我的模块代码基本上是:在node.js中承诺蓝鸟的问题
// ofr-network/index.js
var requireDir = require('require-dir');
var models = requireDir('./models');
var network = {
getReportsFromCity: function(cityId) {
models.index.reports.findAll({
where: { id: cityId },
attributes: ['id', 'latitude', 'longitude']
}).then(function(reports) {
console.log('[NETWORK-OFR] Get reports from %s', cityId);
return reports;
}).catch(function(err){
console.log('Error getting reports from %s', cityId);
console.log(err);
});
}
}
module.exports = network;
那么,这段代码工作正常。现在我正在尝试在我的快速应用程序中使用此模块,导入并调用此方法,但此代码不返回任何内容。我查过了,看到我必须使用承诺,一旦上面的代码是异步的。 我的API方法的代码如下:
var express = require('express');
var app = express();
var router = express.Router();
var network = require('ofr-network');
var Promise = require('bluebird');
router.get('/', function(req, res) {
var getReports = Promise.promisify(network.getReportsFromCity, network);
getReports(538).then(function(reports) {
console.log('DONE');
// this print isn't running
}).catch(function(err){
console.log(err);
});
res.render('index.html', { title: 'Title page' });
});
module.exports = router;
有人能帮助我吗?
你为什么promisify'getReports'? promisify是为了使回调函数返回承诺,'getReports'已经返回一个承诺 – Esailija