use*_*195 12 javascript node.js promise
我已嵌套数组,我能够检索第二级数组的promise,但不知道如何实现then一次顶级结束.
result.forEach(function(entity){ // outer list ???
return Promise.all(entity.urls.map(function(item){
return requestURL(item.href);
}));
});
Run Code Online (Sandbox Code Playgroud)
例如,如果results有两个或两个以上项目,每个item有10个或多个URL抓取,我们将如何实现then的[Promise.all][1]所有承诺.原生解决方案请.
基本上以正确的方式处理嵌套的promises数组.
数据结构:
var result = [
{
urls: [
{href: "link1"},
{href: "link2"},
{href: "link3"}
]
},
{
urls: [
{href: "link4"},
{href: "link5"},
{href: "link6"}
]
}
];
Run Code Online (Sandbox Code Playgroud)
Ori*_*iol 21
使用map而不是forEach,并将其包装在另一个Promise.all调用中.
var arr = [
{subarr: [1,2,3]},
{subarr: [4,5,6]},
{subarr: [7,8,9]}
];
function processAsync(n) {
return new Promise(function(resolve) {
setTimeout(
function() { resolve(n * n); },
Math.random() * 1e3
);
});
}
Promise.all(arr.map(function(entity){
return Promise.all(entity.subarr.map(function(item){
return processAsync(item);
}));
})).then(function(data) {
console.log(data);
});Run Code Online (Sandbox Code Playgroud)
您还可以使用立即调用的生成器.例如,要获得扁平的结果,
var arr = [
{subarr: [1,2,3]},
{subarr: [4,5,6]},
{subarr: [7,8,9]}
];
function processAsync(n) {
return new Promise(function(resolve) {
setTimeout(
function() { resolve(n * n); },
Math.random() * 1e3
);
});
}
Promise.all(function*() {
for(var entity of arr)
for(var item of entity.subarr)
yield processAsync(item);
}()).then(function(data) {
console.log(data);
});Run Code Online (Sandbox Code Playgroud)