>웹 프론트엔드 >JS 튜토리얼 >JavaScript의 For 루프 내에서 비동기 함수를 호출할 때 클로저 문제를 피하는 방법은 무엇입니까?

JavaScript의 For 루프 내에서 비동기 함수를 호출할 때 클로저 문제를 피하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-28 02:03:31851검색

 How to Avoid Closure Pitfalls when Calling Asynchronous Functions Inside a For Loop in JavaScript?

for 루프 내에서 비동기 함수 호출: 클로저 제한 극복

JavaScript의 클로저는 강력한 범위 지정 메커니즘을 제공하지만 다음과 결합하면 문제에 직면할 수 있습니다. for 루프 내의 비동기 함수. 이 문제는 루프 내에서 실행되는 콜백이 항상 마지막 루프 반복을 반영하여 예상치 못한 결과를 낳는 i에 의존할 때 나타납니다.

클로저의 함정

에서 설명된 바와 같이 콜백의 인수로 클로저를 사용하려고 하면 범위 지정 문제가 발생합니다. 현재 반복 인덱스를 캡처하기 위해 (function(x){return x})(i) 또는 create_closure(i)()와 같은 클로저를 사용함에도 불구하고 반환된 값은 최종 루프 반복을 일관되게 반영합니다.

더 나은 솔루션: forEach

이 문제를 해결하려면 배열의 요소를 반복하는 JavaScript의 forEach 메서드를 활용하는 것이 좋습니다. 목록 항목과 해당 인덱스를 모두 콜백에 대한 인수로 제공하여 폐쇄 문제를 제거합니다.

<code class="js">list.forEach(function(listItem, index){
  mc_cli.get(listItem, function(err, response) {
    do_something(index);
  });
});</code>

forEach를 사용하면 각 콜백 호출이 자체 범위 내에서 작동하여 특정 반복에 대한 올바른 인덱스에 액세스합니다. . 이렇게 하면 do_something(i)이 예상대로 for 루프 내에서 의도한 인덱스에 액세스할 수 있습니다.

위 내용은 JavaScript의 For 루프 내에서 비동기 함수를 호출할 때 클로저 문제를 피하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.