시작은 프리캠프 final 과제 질문
안녕하세요 과제 중 해결되지 않는 문제가 있어 문의 드립니다.
인증 확인 버튼을 누를 때
'인증이 완료되었습니다' 안내창 띄우기
안내창 확인을 누르면, 인증 확인 버튼 텍스트 인증 완료로 변경
인증 확인 버튼 비활성화
가입하기 버튼 활성화
과정을 하고 있습니다.
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 이 키워드로 해결책을 검색하며 찾아봤는데요, 혹시 더 적절한 검색 키워드가 있다면 그것도 추천 부탁합니다. 검색도 기술인 것 같은데 요령이 없네요.
답변 1
1
안녕하세요! 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 부분이 최초 한 번만 실행되도록 수정하는 방법 등이 있겠네요!^^
강의자료
0
5
1
윈도우에서 Node js를 설치하고 싶어요
0
12
0
addToFile function에서 path를 사용해 새로운 파일을 생성
0
32
1
[46강] EventEmitter를 활용한 10가지 패턴 중 플러그인 아키텍처
0
29
2
강의가 누락된것 같습니다.
0
37
2
용어 발음법이 계속 바뀌는 것 같은데 이런 부분들 개선이 가능할까요...?
0
47
1
counter01.html은 어디있을까요?
1
16
1
존재하지 않는 일기 url입력 시 alert이 두 번 떠요
0
41
1
useState 직접 구현 부분에서 질문이 있습니다.
1
46
1
학습을 하고 블로그에 정리를 해도 괜찮을까요?
1
45
1
교재(3쇄)와 강의 내용 문의
0
37
2
섹션2번 부분 강의 화면이 잘 못된것 같아서 문의합니다.
0
24
1
call stack 표현이 잘못표현된것이 아닌가요?
0
83
2
React 와 Virtual DOM 의 이야기 영상 실행이 안됩니다.
0
35
1
일반 강의와 차이점?
1
59
1
!= 연산자의 역할
0
36
1
중요하진 않지만 설명하신부분에서 안된부분..
1
39
1
강의 듣는 순서가 어떻게 되나요?
0
54
1
stopPropagation()에 대해서 질문 있습니다.
0
53
2
섹션1 : 시작은 프리캠프 final 과제 타이머 부분 JS 문의
0
467
1
Javascript Exercise Problem List 문
0
379
1
투두리스트 배경화면 적용 404 오류
0
639
1
점 표기법과 []표기법에 대해
1
537
1
섹션5 | Javascript 응용과 싸이월드 실습 4탄 복습 학습자료
0
604
1





