Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/34.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript (节点)运行n次的动态承诺_Javascript_Node.js_Dynamic_Promise - Fatal编程技术网

Javascript (节点)运行n次的动态承诺

Javascript (节点)运行n次的动态承诺,javascript,node.js,dynamic,promise,Javascript,Node.js,Dynamic,Promise,我有一个包含用户信息的对象数组 var names=[{name: 'yoda', address:'123 Compton', email:'yodalicious@force.com'}, {name: 'darth vader', address:'69 harlem', email:'elevader@force.com'},{....}] 这是一个范围从10

我有一个包含用户信息的对象数组

var names=[{name: 'yoda', 
            address:'123 Compton', 
            email:'yodalicious@force.com'},
            {name: 'darth vader', 
            address:'69 harlem', 
            email:'elevader@force.com'},{....}]
这是一个范围从100到1000用户的列表。 问题是,我需要从web和DB请求/提取关于每个用户的信息,并创建一个包含关于每个用户的更多详细信息的新数组。这将是3个来源。现在,每次拉动需要10毫秒到1分钟的时间。 这就是我跳转到承诺的地方。仅限本机承诺,例如:

require("native-promise-only");

function getFile(file) {
    return new Promise(function(resolve){
        fakeAjax(file,resolve);
    });
}
//Recursive call
function recursivePromise(originalArray, newArray){
 if(isEmpty(originalArray) ){
  store(newArray);
  display(newArray);
}
else{
  var currentItem = originalArray[0];
  var p1 = getFile(currentItem.name);
  var p2 = getFile(currentItem.address );
  var p3 = getFile(currentItem.email);

  var newDataItem={};
  p1.then(function(msg){
    //TODO check status
    newDataItem.nameinfo= msg;
    return p2;
  })

  .then(function(msg){
    //TODO check status
    newDataItem.addressinfo= msg
    return p3;
  })

  .then(function(msg){
    newDataItem.emailinfo= msg
    newArray.add(newDataItem);
    recursivePromise(originalArray.shift(), newArray)
  });
}
}
var new_array=[];
recursivePromise(names, new_array);
这是一个粗略的代码,我有类似的东西,它的工作!有点但我身上的一个缺陷告诉我,我可能会导致未来的失败。我递归地这样做是因为项目在“名称”中的位置很重要。因此,它们需要按顺序进行处理

我所看到的问题:

编码错误:

果实不知从何而来;大概是原计划的。 array.shift从数组中删除第0个元素,并返回删除的元素,而不是数组。 原始阵列将被摧毁,这不是一个好主意。 .add可能不是数组方法。push是有意的。 模式问题:

p1。然后……然后。。。链是构建新数据项的一种相当麻烦的方式;答应我。所有的P1,p2,p3。然后。。。如果在单个表达式中构建newDataItem,则更具可读性。 递归是不必要的;这个过程将更简单地编码为。。。;Promise.allarrayOfPromises.thenfunctionnewArray{…};这是承诺的第二种用法;尽管承诺将以他们喜欢的任何顺序解决,但newArray将与originalArray一致。 可以在内部生成newArray,而无需传入[]。
displaynewArray和storenewArray都可以在内部或外部执行。我在上面把它们分开来演示这两种可能性。

什么是水果?你为什么要移动它?什么是。添加到数组上?要在第一个请求完成之前连续运行请求而不启动第二个请求,还是要同时并行运行最多X个请求?゚o゚ -看起来很干净。非常感谢。我必须尽快想出一个解决方案,递归就是我能想到的一切。你让我的黑客行为蒙羞了。收集乱七八糟的部分应该会让你读起来很有趣。
function process(originalArray) {
    var promises = originalArray.map(function(currentItem) {
        var p1 = getFile(currentItem.name);
        var p2 = getFile(currentItem.address);
        var p3 = getFile(currentItem.email);
        return Promise.all([p1, p2, p3]).then(function(results) {
            return {
                nameinfo: results[0],
                addressinfo: results[1],
                emailinfo: results[2]
            };
        });
    });
    return Promise.all(promises).then(function(newArray) {
        display(newArray);
        return newArray;
    });
}
process(names).then(function(newArray) {
    store(newArray);
});