【发布时间】:2016-07-07 14:18:39
【问题描述】:
我知道在 Nodejs/Express 中链接 Promise 的最佳方式是:
doSomeThing()
.then()
.then()
.catch();
但最近不得不使用 async 和 q 模块来迭代列表/数组并运行异步函数。我想知道有没有更好的方法来做/写这个-
var deferred = Q.defer();
var deferred2 = Q.defer();
models.Local.findOne({
where: {
id: parseInt(req.body.localid)
}
})
.then(function(resultLocal){
if(!resultLocal){
return res.status(404).json(
{
"status" : "error",
'error': "Local Not Found"
});
}
return models.Documents.create(req.body.document);
})
.then(function(docCreated){
var attributes = req.body.document.Attributes;
async.each(attributes, function(item, callback) {
models.Doc_Tags.create({
value: item.value,
attribute_id: item.id,
document_id: docCreated.id
})
.then(function(attributeCreated){
var upObj = {};
upObj[item.col_name] = item.value;
models[item.table_name].update(upObj,{
where:{
id: req.body.document.local_id
}
})
.then(function(primaryUpdated){
deferred2.resolve();
})
.catch(function(error){
return res.status(400).json({status: 'error', error:error.message});
});
deferred2.promise
.then(function(){
callback();
})
.catch(function(error){
return res.status(400).json({status: "error", error: error.message});
});
})
.catch(function(error){
return res.status(400).json({status: 'error', error:error.message});
});
}, function(err,r){
if( err ) {
return res.status(400).json({status: 'error', error:err.message});
} else {
console.log('All attributes Associated');
deferred.resolve(docCreated);
}
});
deferred.promise.then(function(result, attributes){
var obj = req.body.Local;
models.Local.update(obj, {
where: {
id: result.local_id
}
})
.then(function(resultUpdate){
return res.status(201).json({status: "success", document: result});
})
.catch(function(error){
return res.status(400).json({status: "error", error: error.message});
});
})
.catch(function(error){
return res.status(400).json({status: "error", error: error.message});
});
})
.catch(function(error){
return res.status(400).json({status: "error", error: error.message});
});
如果我做错了什么,请纠正我。功能方面,代码运行正常,但我认为我可以以某种方式对其进行重构以更好地查看和阅读。
谢谢。
【问题讨论】:
-
不将
async.js与promise一起使用是这里最重要的良好实践。 -
@AlongkornChetasumon 当 OP 不使用该库时,您不能只将 bluebird 标记添加到问题中!
-
看看deferred antipattern 以及如何避免它。
标签: javascript node.js express promise q