来限制并发访问的次数,但 promise.all((.then(( 不起作用,标志总是假的,为什么!!
function getPage(singeUrl) {
return new Promise((resolve,reject)=>{
superagent.get(singeUrl)
.set({'Content-Type': 'application/json',
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.96 Safari/537.36'})
.charset('utf8')
.end(function (err, sres) {
if (err) throw err;
utils.singleRequest(sres,db)
});
resolve('resolve=='+singeUrl)
})
}
let flag = true;
pages.forEach((item) => {
if(flag){
flag = false;
let promises = item.map(function (url) {
return getPage(url);
});
Promise.all(promises).then(res => {
flag = true;
})
}
})
编辑:
问题在于,因为您正在循环遍历多维承诺数组,并且由于条件if (flag)
依赖于 flag 为 true 来执行 pages.forEach()
中的任何代码,因此循环在第一次迭代后停止执行任何代码。这是因为Promise.All()
是异步操作。当从pages[0]
创建的承诺解析时(这也将flag
设置为 true
(,迭代已经完成了它的第一个循环,但flag
仍然设置为 false
。
您可以通过扁平化多维承诺数组来解决此问题,这样Promise.all()
将一次等待所有承诺,而不是遍历它们。
我对您的代码进行了一些更改来演示这一点:
let pages = [];
pages.push(['one', 'two']);
pages.push(['three', 'four']);
pages.push(['five', 'six']);
let getPage = function(singeUrl) {
return new Promise((resolve, reject)=>{
resolve('resolve=='+singeUrl)
if(!singleUrl) reject('No input');
});
}
let flag = true;
pages.forEach((item) => {
if(flag){
flag = false;
let promises = item.map(function (url) {
// You will notice in the output at the bottom, that
// only the array pages[0] have been executed by Promise.all()
console.log('url: ', url);
return getPage(url);
});
Promise.all(promises).then((res) => {
// The log statements below are executed last
console.log('flag1 in promise: ', flag);
flag = true;
console.log('flag2 in promise: ', flag);
});
}
});
// This statement executes before flag
// is set to true
console.log('final flag: ', flag);
输出:
url: one
url: two
final flag: false
flag1 in promise: false
flag2 in promise: true