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

home2 게시판 Vue 게시판 setInterval() 에서 적용하기

setInterval() 에서 적용하기

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

    이치호
    참가자

    mounted(){
    setInterval(()=>{
    this.amount--
    },1000);
    if (this.amount === 0){
    clearInterval(setInterval())
    }
    },

     

    일단 코드는 이렇게 짰습니다.

    props로 Discount.vue에다가 데이터 전송도 했습니다.

    저 코드는 부모창에 있는 코드들입니다.

    amount가 0을 찍으면 Interval을 종료하려고 하는데 도저히 안 됩니다.

     

    해본 것들

    저 코드로 시도해본다.

    setInterval()을 변수로 만들어 clearInterval(setInterval(변수명)) 으로 끝낸다.

    clearInterval 을 사용하지 않고 amount가 amount--를 통해 0이 됐을 때 this.amount 를 0으로 할당해버린다

    자식 데이터 만지는 것도 아닌데... 왜 끝나지 않는 걸까요.... 한시간 넘게 고민했습니다 인터넷도 찾아보고 ㅠㅠ

    알려주세요~~

    #13945

    codingapple
    키 마스터

    var 타이머 = setInterval(()=>{ 

    이렇게 변수에 저장해뒀다가 

    타이머 제거가 필요할 때 clearInterval() 안에 변수명 넣으면 됩니다 

    그리고 mounted() 는 컴포넌트가 장착될 때 안에있는 코드를 한번 실행해주는 역할이라서요 지금 있는 if문은 맨 처음 한번 실행되고 다시는 실행되지 않습니다

    mounted 말고 다른 방법이 필요할듯요 

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 호 / 개인정보관리자 : 박종흠