【发布时间】:2013-09-20 12:12:57
【问题描述】:
我正在尝试使用递归调用从 redis 中获取数据,当成员返回 null 时停止并返回。
所以我的数据是这样添加的:
SADD parents.<name> <parent1> <parent2>
SADD parents.<parent1> <grandparent1> <grandparent2>
...
最终的数据应该是这样的:
[
{
label: <name>,
parents: [
{ label: <parent1>,
parents: [ {label: <grandparent1>}, {label: <grandparent2> }] },
{ label: <parent2> }
]
}
]
这是我正在弄乱的代码(从不同的来源拼凑而成),但我不知道我在做什么。不确定这段代码是否有用,我可能会偏离轨道。
var redis = require('node-redis');
var r_client = redis.createClient();
var Q = require('q');
function getFromRedis(nodeName){
var ret = Q.defer();
r_client.smembers('parents.' + nodeName,function(err,val){
if (err) ret.reject(err);
else {
var constructedObject={}; //this is our returned object
var dependents=[];
if (val)
{
for (var k in val){ //iterate the keys in val
constructedObject.name = val[k];
dependents.push(getFromRedis(val[k])
.then(function(subVal){
constructedObject[k]=subVal;
return ret.promise;
})
);
}
}
else { return [] }
}
Q.all(dependents)
.then(function(){ret.resolve(constructedObject);},ret.reject.bind(ret));
});
return ret;
}
getFromRedis( 'greg', function(out) {console.log('Final output: ' + JSON.stringify( out ))} );
我可以查看示例并从理论上了解它应该如何工作,但我不知道它应该如何与 q 实现一起工作。任何帮助将不胜感激。
【问题讨论】:
-
您之前是否有基于回调的解决方案?
-
没有。我试过了,但它要复杂得多。
标签: javascript node.js recursion promise