簡體   English   中英

(節點)運行n次的動態承諾

[英](Node) Dynamic promises that run n-times

我有一個包含用戶信息的對象數組。

var names=[{name: 'yoda', 
            address:'123 Compton', 
            email:'yodalicious@force.com'},
            {name: 'darth vader', 
            address:'69 harlem', 
            email:'elevader@force.com'},{....}]

此列表的范圍為100到1000個用戶。 問題是我需要從Web和數據庫請求/拉取有關每個用戶的信息,並創建一個包含有關每個用戶更多詳細信息的新數組。 這將是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);

這是一個粗略的代碼,我有類似的東西,並且可以工作! 有些。 但是我的一個錯誤告訴我,我可能會設置將來的失敗。 我之所以進行遞歸操作,是因為該項目在“名稱”中的位置很重要。 因此需要對其進行順序處理。

我看到的問題:

編碼錯誤:

  • fruits無處不在; 大概是originalArray.shift() array.shift originalArray.shift()
  • array.shift()從數組中刪除第0個元素,並返回刪除的元素,而不是數組。
  • originalArray將被銷毀,這不是一個好主意。
  • .add()不是數組方法,大概是.push()目的。

模式問題:

  • p1.then(...).then(...)鏈是一種構建newDataItem的相當麻煩的方法; Promise.all(p1, p2, p3).then(...)更具可讀性,因為newDataItem內置在單個表達式中。
  • 不需要遞歸; 該過程將更簡單地編碼為...; Promise.all(arrayOfPromises).then(function(newArray) {...}); ...; Promise.all(arrayOfPromises).then(function(newArray) {...}); (這是Promise.all()的第二次使用); 盡管promise將以他們喜歡的任何順序解決,但是newArray將與originalArray保持一致。
  • newArray可以在內部生成,而無需傳遞[]
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);
});

display(newArray)store(newArray)都可以在內部或外部執行。 我在上面拆分了它們,以展示這兩種可能性。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM