在nodejs中,许多函数调用被实现为非阻塞函数。有时这些函数调用之间可能存在依赖关系。例如,当用户登录时,我想先获取用户的用户类型,然后根据用户类型,我可以获得刚刚分配了此用户类型的任务。在非阻塞函数中,我使用嵌套函数调用:
$http.post(url_login, login_request)
.success(function(req) {
$http.post(url_get_tasks, req.type)
.success(function(req) {
//update tasks
})
})
许多库仅提供非阻塞功能,例如node_redis库。有没有什么好方法可以处理嵌套的非阻塞函数调用来解决依赖性问题。
答案 0 :(得分:1)
有一个专门针对此问题的页面:http://callbackhell.com/
总而言之,您可以选择
如果我没弄错的话,
您正在使用Angular $http
服务,该服务应该支持正确
承诺链接,所以你可以减少你的代码
$http.post(url_login, login_request)
.then(function(req){
return $http.pos(url_get_tasks, req.type);
})
.then(function(req){
// update tasks
})
.catch(function(err){
// errors from the first AND second call land here
})
您可以为异步函数编写一个简单的包装器,将它们转换为promise:
// this assumes standard node.js callbacks with the
// signature (error, data)
function toPromise(fn){
return function() {
var args = Array.prototype.slice.call(arguments);
var scope = this;
return new Promise(function(resolve, reject){
var cb = function(err, data) {
return err ? reject(err) : resolve(data);
};
args.push(cb);
fn.apply(scope, args);
});
};
}
// turn fs.readdir into a promise
var readdir = toPromise(require('fs').readdir);
readdir('.')
.then(function(files){
console.log(files);
})
.catch(function(err){
console.log('reading files failed');
})
还有另一个关于Angular $http
承诺的问题可能有助于您更好地理解它们:here
答案 1 :(得分:0)
我不是100%肯定你在问什么,但是如果你想减少代码中的嵌套,你可以像这样移动内部函数:
function success1(req) {
//update tasks
}
function success2(req) {
$http.post(url_get_tasks, req.type).success(success1)
}
$http.post(url_login, login_request).success(success2)
显然你应该选择比success1