• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 JavaScript, TS 게시판 for 반복문과 전역 변수

for 반복문과 전역 변수

2 글 보임 - 1 에서 2 까지 (총 2 중에서)
  • 글쓴이
  • #62762

    고영민
    참가자
    <출처>
    쉽게 이해하는 JavaScript 객체지향 & ES6 신문법
    '변수 연습문제' 수업 관련 질문입니다.
    
    <수업 내용>
    아래 코드의 문제는 0,1,2,3,4,5 이렇게 출력되어야 하는데, 5만 출력되는 문제라고 하셨습니다.
    for (var i = 0; i < 6; i++) {
     setTimeout(() => {console.log(i)}, i*1000)
    }
    
    이 문제의 원인은 setTimeout의 콜백함수(console.log...)를 실행하기 전에(setTimeout이니 딜레이가 있겠죠)
    반복문이 계속 실행되어서 결국 i = 5가 되어서야 콜백함수가 실행된다는 점입니다. 
    이를 해결하기 위해
     var -> let 으로 바꾸면 해결된다고 하셨고, 결국 해결은 됩니다. 
    
    <질문 내용>
    var를 let으로 바꾼다고 왜 문제가 해결되는지 이해가 안갑니다.
    문제의 원인은 반복문의 실행 속도와 setTimeout 코드의 실행 속도 차이인데,
    var를 let으로 바꾼다고 왜 해결되는지 모르겠습니다..
    답변 부탁드립니다. 
    
    
    #62767

    codingapple
    키 마스터
    setTimeout안의 코드는 몇초 후에 실행되는데
    그때 안에 있던 i 변수를 주변에서 찾아서 사용합니다 
    근데 주변에 있는 i값이 var과 let 쓰는 경우마다 달라집니다
2 글 보임 - 1 에서 2 까지 (총 2 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관, 개인정보처리방침
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠