인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

Droid님의 프로필 이미지
Droid

작성한 질문수

진짜! 자바스크립트(Javascript) - 기초부터 고급까지

변수 스코프(함수 스코프와 블록 스코프) 그리고 VAR 변수의 문제점 1편 📕

for 문에서 var 키워드 변수를 사용할 때와 let 키워드 변수를 사용할 때 차이점

해결된 질문

작성

·

33

0

안녕하세요 좋은 강의 감사드립니다.

아래에서 for 반복문 내에서 var 키워드를 사용했을 때의 경우에는 var 키워드는 함수 스코프를 가지므로 setTimeout 의 콜백 함수가 실행되는 시점에 i 변수의 값은 이미 3인 상태이므로 3 3 3이 출력되는 것은 이해를 했습니다.

 

그런데 let 키워드로 선언한 변수는 블록 스코프를 가지는데 언뜻 이해하기로는 for 블록 내부에 i 변수가 선언되었다고 생각하면 var 키워드와 마찬가지로 setTimeout 의 콜백 함수가 호출되는 시점에 i 변수는 3이어야 하는게 아닐까라는 생각이 듭니다. 근데 0 1 2 가 출력되는 것을 보면 혹시 for 반복이 한번 실행될 때마다 i 변수가 생성되어서 서로 다른 블록 스코프를 가지는 것인지 아니면 제가 이해하지 못한 다른 내용이 있는 것인지 궁금합니다!

 

그리고 마지막으로 블록 스코프란 { } 이렇게 중괄호 내에 선언되는 경우를 말하는 것 같은데 for 문의 let i 변수의 경우에는 정확히 말하면 블록 내부에 선언되어 있지는 않은데 이 경우에도 블록 스코프라고 봐야 하는 건가요??

 

감사합니다!

function timer() { 
  for (var i = 0; i < 3; i++) { 
    setTimeout(function () { 
      console.log(i); }
    , 1000); 
  } 
}
function timer() { 
  for (let i = 0; i < 3; i++) { 
    setTimeout(function () { 
      console.log(i); }
    , 1000); 
  } 
}

답변 1

0

코딩맥스 CodingMax님의 프로필 이미지
코딩맥스 CodingMax
지식공유자

안녕하세요 Droid 님! 질문 주셔서 감사합니다 😊

해당 내용은 현재 수강하고 계신 강좌 중 아래 강좌에서 자세한 내용을 설명하고 있습니다.

감사합니다 😊

 

Droid님의 프로필 이미지
Droid

작성한 질문수

질문하기