inflearn logo
강의

Course

Instructor

[Code Camp] A highly concentrated front-end course created at Bootcamp

시작은 프리캠프 final 과제 질문

Resolved

391

zerone

7 asked

0

안녕하세요 과제 중 해결되지 않는 문제가 있어 문의 드립니다.

 

인증 확인 버튼을 누를 때

과정을 하고 있습니다.

const timer__button = () => {
    alert("인증이 완료되었습니다.")
    document.getElementById("timer__button").innerText = "인증 완료"
    document.getElementById("timer__button").disabled = true
    document.getElementById("submit").disabled = false
}

인증 확인 버튼을 누르면,

'인증이 완료되었습니다.' 안내창이 뜨고, 인증 확인에서 인증 완료로 텍스트가 변경됩니다.

하지만 버튼의 활성화와 비활성화가 되지 않습니다.

 

타이머가 작동되고 있는 동안 타이머가 활성화되도록 한 코드 때문에 씹히는 걸까요? 혹시 몰라 타이머 부분 코드도 첨부합니다.

const randomNumber__button = () => {

    document.getElementById("randomNumber__button").disabled = true

    let randomNumber = String(Math.floor( Math.random() * 1000000 )).padStart(6,"0")
    document.getElementById("randomNumber__number").innerText = randomNumber

    let time = 7
    let timer = true
    timer = setInterval(function(){
        if(time >= 0){
            let min = Math.floor(time/60)
            let sec = String(time%60).padStart(2,"0")
            document.getElementById("timer__number").innerText = min + ":" + sec
            time = time - 1

            document.getElementById("timer__button").disabled = false
        } else {
            document.getElementById("timer__button").disabled = true
            document.getElementById("randomNumber__number").innerText = "000000"
            document.getElementById("timer__number").innerText = "3:00"

            clearInterval(timer)
        }
    },1000)
}

 혹시 이 코드에 영향을 받아 버튼 비활성화가 안 되는 거라면 타이머 숫자를 3:00(기본 세팅 값)으로 바꾸면 될까 했지만 역시 안 됐습니다.

const timer__button = () => {
    document.getElementById("timer__button").innerText = "인증 완료"
    alert("인증이 완료되었습니다.")
    document.getElementById("timer__number").innerText = "3:00"
    // document.getElementById("timer__button").disabled = true
    // document.getElementById("submit").disabled = false
}

 

 

여기저기 찾아본 결과 alert 기능은 안내창이 떠 있는 동안 동작을 일시정지 시키고, alert 다음으로 이어지는 동작을 적어줄 땐 첨부 코드와 같이 단순 나열로 가능하다고 합니다. 다른 코드들 찾아봤을 때도 제가 쓴 코드와 유사했고요.

 

어느 부분이 문제인 건지, 만약 앞서 작성한 타이머 코드 때문에 씹히는 거라면 어떻게 해결해야 좋을지 힌트를 좀 받고 싶습니다.

alert button disabled 이 키워드로 해결책을 검색하며 찾아봤는데요, 혹시 더 적절한 검색 키워드가 있다면 그것도 추천 부탁합니다. 검색도 기술인 것 같은데 요령이 없네요.

javascript

Answer 1

1

nwd09074926

안녕하세요! zero.1.0.one.xx님!

올려주신 코드를 보니, setInterval 부분이 아래와 같이 작성되어 있네요!

       if(time >= 0){
            let min = Math.floor(time/60)
            let sec = String(time%60).padStart(2,"0")
            document.getElementById("timer__number").innerText = min + ":" + sec
            time = time - 1

            document.getElementById("timer__button").disabled = false
        } else {
            document.getElementById("timer__button").disabled = true
            document.getElementById("randomNumber__number").innerText = "000000"
            document.getElementById("timer__number").innerText = "3:00"

            clearInterval(timer)
        }

 

이 중에서, 타이머가 아직 끝나지 않은 경우에 1초에 1번씩 계속 실행되는 코드는 아랫부분 일거구요!

       if(time >= 0){
            let min = Math.floor(time/60)
            let sec = String(time%60).padStart(2,"0")
            document.getElementById("timer__number").innerText = min + ":" + sec
            time = time - 1

            document.getElementById("timer__button").disabled = false
       } else {
            // ...
       }

 

다시말해, if문 안의 마지막줄 document.getElementById("timer__button").disabled = false 이 코드가 1초에 1번씩 실행되기 때문에, disabled = true로 비활성화 시켰다고 하더라도 다시 풀려나게 돼요!

문제를 해결하기 위해서는 1. 인증 완료시 timer가 더이상 작동하지 않도록 만들거나, 2. 위 코드에서 disabled = false 부분이 최초 한 번만 실행되도록 수정하는 방법 등이 있겠네요!^^

1

zerone

감사합니다.

프론트엔드 학습 수준 문의

0

17

2

리액트 챕터별 코드에서 eslint 설정파일이 없어요

0

35

2

최근 코테, 과제 테스트 트렌드

0

49

2

lucide react 아이콘 설치

0

34

2

17강 zustand store 서버에서 생성

1

29

1

문의관련 문의

0

36

2

next.js 를 2대이상 실행하는 경우 제공하는 cache 기능들은 어떻게 되나요?

0

46

2

76. 전문성 더하기: 놓치면 아쉬운 관련 기술들 수업 자료가 없어요.

0

40

2

ai 도구 질문

0

27

1

저는 왜 콘솔에서 props가 한 줄만 찍히나요?

0

43

1

렌더링 차단 리소스 javascript 실행에 관련해서 질문 있습니다.

0

41

2

데이터 로딩중 화면만 계속 나와요!!

0

47

2

퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요

0

71

2

02-04 layout.tsx 구조가 달라요

0

53

2

불변성을 지키며 수정 삭제를 할때도 Map이 유리한가요?

0

47

1

개인 프로젝트로 앱 개발해서 다운로드 1300 달성했는데 어느 정도 의미가 있을까요? (안드로이드 개발자)

0

64

1

22강 강의 영상 문의 드립니다.

0

45

2

20강 마무리작업에서

0

35

2

아래 위치에 동영상이 보이지 않습니다.

0

51

1

섹션1 : 시작은 프리캠프 final 과제 타이머 부분 JS 문의

0

462

1

Javascript Exercise Problem List 문

0

368

1

투두리스트 배경화면 적용 404 오류

0

622

1

점 표기법과 []표기법에 대해

1

527

1

섹션5 | Javascript 응용과 싸이월드 실습 4탄 복습 학습자료

0

597

1