promise.all().then not work


我使用 promise.all

来限制并发访问的次数,但 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

最新更新