[英]Sequentially executing promises inside a for loop
我在循环中链接两个承诺,所以承诺二号,直到承诺一解决后才开始。
我看到了一个减少的例子。 无法让它发挥作用。 如果我就这样做,就像我现在所做的那样,代码并行执行 - 就像在所有异步请求被触发一样,当然结果搞砸了。 请看一下:
for ( var i = 0; i < dummyData.accounts.length; i++) {
var cursorUser = dummyData.accounts[i];
var auth0User = {
email: cursorUser.email,
password: 'abc123',
connection: 'Username-Password-Authentication'
};
createUser(api, auth0User)
.then(function (auth0Info) {
return auth0Info;
})
.then(function(auth0Info) {
cursorUser.authProfile = auth0Info;
console.log("account: ", cursorUser);
return create(accountsAPIService, cursorUser);
})
}
简单地避免for
异步工作循环。
数组有像forEach
这样的函数方法和map
这样的东西。
var pendingResults = dummyData.accounts.map(function (account) {
return createUser(api, {
email: account.email,
password: 'abc123',
connection: 'Username-Password-Authentication'
}).then(function (authInfo) {
console.log("account: ", authInfo);
return create(accountsAPIService, authInfo);
});
});
Promise.all(pendingResults).then(function (results) {
// everything is done
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.