如何处理循环中调用的异步函数?

时间:2020-04-06 22:04:39

标签: javascript callback

我试图了解如何获取for循环以等待函数完成,然后再进行下一次迭代。我想我想使用回调,但是我不确定该怎么做。在我的示例中,我希望循环等待setTimeout以便数组中的数字以正确的顺序显示:

var myArr = [1,2,3];
$('#myButton').on('click',function1);

function function1() {
	for(var i = 0; i < myArr.length; i++) {
  	function2(myArr[i]);
  }
}

function function2(number) {
	if(number == 2) {
  	setTimeout(function(){$('#myDiv').append('<div>'+number+'</div>');},1000);
  } else {
  	$('#myDiv').append('<div>'+number+'</div>');
  }
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<button id="myButton">test</button>
<div id="myDiv"></div>

1 个答案:

答案 0 :(得分:0)

您可以使用Promise和async / await来实现。从function2()返回一个承诺,如果满足条件,则在一段时间后解决Promise,否则立即解决它。这是一个工作示例:

async function function1() {
  for (var i = 0; i < myArr.length; i++) {
    await function2(myArr[i]);
  }
}

function function2(number) {
  return new Promise((resolve, reject) => {
    if (number == 2) {
      setTimeout(function () {
        $('#myDiv').append('<div>' + number + '</div>');
        resolve();
      }, 1000);
    } else {
      $('#myDiv').append('<div>' + number + '</div>');
      resolve();
    }
  });
}