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

home2 게시판 JavaScript, TS 게시판 setTimeout 강의 숙제 질문있습니다.

setTimeout 강의 숙제 질문있습니다.

  • 이 주제에는 2개 답변, 3명 참여가 있으며 codingapple3 년 전에 전에 마지막으로 업데이트했습니다.
3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 글쓴이
  • #36996

    KSD
    참가자

    강의 숙제에서 0일 때 div가 안 보이게 처리하라는 응용숙제까지 내주셨는데,

    var count=5;

     var 타이머 = setInterval(function(){
      count -= 1;
      if(count>=0){
        document.querySelector('.num').innerHTML=count;
      }else{
        document.querySelector('.alert').style.display='none';    
      }
    },1000)

     

    이렇게 else로 했더니 사라지긴 했습니다.

     

    그런데 이렇게 하고보니 의문점이  드는 게 setInterval함수는 ~초마다 반복하게 해주는 함수잖아요?

    그러니  count -= 를 해주었으니, 

    화면상에선 보이지 않지만

    document.querySelector('.alert').style.display='none';    이 부분이 계속 반복될 수도 있다는 생각이 들었습니다. 

    계속 반복되는 걸까요, 아니면 저 구문을 한번실행함으로써 끝나는 걸까요?

     

    만일 반복되는 거라면, setInterval을 끝내기 위해서 clearTimeout을 써주어야할텐데,

     

    var count=5;
     setInterval(function(){
      count -= 1;
      if(count>=0){
        document.querySelector('.num').innerHTML=count;
      }else{
        document.querySelector('.alert').style.display='none';
        clearTimeout(타이머)    
      }
    },1000)

    저 자리에 들어가는 게 맞을까요? 

     

     

    #37058

    이화영
    참가자

    if  A else B 가   만약 (조건이 성립한다면 )  a 고 (조건이 성립하지 않다면 ) b 라는 뜻이라 

     

    else{
        document.querySelector('.alert').style.display='none';    
      } 

    해석했을때 

    (아니라면 display 를 none으로 해주세요.) 라는뜻이니 

    반복되지 않지않을까요?

    #37076

    codingapple
    키 마스터

    if와 else 안에 있는 코드는 둘 중 무조건 하나만 실행됩니다

    clearTimeout 안에 넣으면 타이머가 아예 제거됩니다 

3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 답변은 로그인 후 가능합니다.

About

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

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

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