JavaScript 클로저와 익명 함수
JavaScript의 일반적인 기능인 익명 함수는 클로저에 대한 논의에서 자주 등장합니다. 그러나 모든 익명 함수가 실제 클로저로 적합한 것은 아닙니다.
클로저 정의
JavaScript의 클로저는 어휘 범위에 대한 액세스를 유지하는 특수한 유형의 익명 함수입니다. 외부 범위가 종료된 후에도 생성되었습니다. 이 기능을 사용하면 클로저가 외부 범위에서 변수 값을 "캡처"하여 변수가 가비지 수집되는 것을 방지할 수 있습니다.
사례 연구: 변수에 대한 닫기
In 주어진 코드 예제에서 두 솔루션 모두 익명 함수를 사용하여 카운터 변수 i의 인쇄를 지연합니다.
Friend's Attempt
첫 번째 예제의 코드는 클로저 내의 i 변수입니다. 그러나 내부 익명 함수 g는 외부 함수 f의 어휘 범위를 상속하지 않기 때문에 클로저 정의를 충족하지 않습니다. 따라서 i는 실제로 "닫힌" 것이 아닙니다.
<code class="javascript">for(var i = 0; i < 10; i++) { (function(){ var i2 = i; setTimeout(function(){ console.log(i2); }, 1000) })(); }</code>
편집자의 시도
두 번째 코드 예제는 실제로 클로저를 생성합니다. 외부 함수 f에 의해 반환된 익명 함수는 i2 변수를 캡처하고 클로저의 어휘 범위 내에서 그 값을 유지합니다. 그런 다음 이 클로저는 setTimeout 콜백 내에서 호출되어 i 변수의 원래 값에 액세스되도록 합니다.
<code class="javascript">for(var i = 0; i < 10; i++) { setTimeout((function(i2){ return function() { console.log(i2); } })(i), 1000); }</code>
결론
제공된 코드에서 편집기의 솔루션은 i 변수의 값을 캡처하기 위해 클로저를 올바르게 사용하는 방법을 보여줍니다. 두 솔루션 모두 인쇄 지연 문제를 효과적으로 해결하지만 편집자의 솔루션만이 기술적인 측면에서 종결에 해당합니다.
위 내용은 익명 함수는 언제 JavaScript에서 클로저가 되나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!