메뉴 건너뛰기

2020.06.21 00:05

예제 9-18번 질문

조회 수 84 댓글 1

<script>
    var sum=0;
    function calc(e) {
        if(e.checked)
            sum+=parseInt(e.value);
        else
            sum-=parseInt(e.value);
        document.getElementById("sumtext").value=sum;
    }
</script>

 

선택된 체크박스의 value값을 전부 더해서 출력하는 문제입니다.

calc함수에서 e.checked가 성립되면 sum에 값을 더하고, 그렇지 않은 경우 sum에서 값을 제한다고 나와있습니다.

저는 e.checked의 경우에만 sum에 값을 더하고, 그렇지 않은 경우에는 아무것도 하지 않는게 맞다고 생각해서,

<script>
    var sum=0;
    function calc(e) {
        if(e.checked)
            sum+=parseInt(e.value);
        else
            return;
        document.getElementById("sumtext").value=sum;
    }
</script>

의 형태가 맞다고 생각했습니다. 하지만 정작 체크를 풀어보니 결과값이 sum에서 빠지지 않았습니다.

ifelse문에서 else가 의미하는 바가 무엇인가요? 단순히 체크가 되지 않은 경우를 의미하는게 아닌가요?

?
  • ?
    관리자 2020.06.21 00:20

    처음에 아무 체크박스가 체크되지 않았을 때 sum이 0입니다.
    이 상태에서 어떤 알고리즘을 사용해야할까요?
    체크를 하면 더해주어야 겠지요.
    체크고 해제고 안 하면 아무런 계산도 일어나지 않겠지요.

    **지금부터가 중요합니다.**
    그런데 calc() 함수가 호출되었습니다. 어떤 경우일까요?
    (1) 체크 안된 박스에 체크하여 체크 상태로 만들었든지
    (2) 체크된 박스에 체크를 해제하였든지
    이겠지요.

    그러므로 calc() 함수 내에서는 다음과 같이 코딩해야 합니다.
    if(e.checked)
    sum+=parseInt(e.value); ---> (1) 체크 안된 상태에서 체크한 경우
    else
    sum-=parseInt(e.value); -----> (2) 체크된 상태에서 체크를 해제한 경우

     

    이 코드에서 calc() 함수가 호출된 것은 체크 선택이나 체크 해제 둘중 하나인 이벤트가 발생하였는데

    이벤트를 조사해보니 e.checked==true라는 것은 체크안된 박스에 체크가 된 이벤트이고

    e.checked==false라는 것은 체크된 박스에 체크를 해제시킨 이벤트가 발생하였음을 나타내는 것입니다.


    천천히 다시 생각해보고, 또 질문하세요.


QnA

공부하면서 궁금했던 것을 질문해보세요.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18281
403 혹시 예전 서적인 "DHTML + 자바스크립트 프로그래밍"의 예제를 받을 수 있는 방법은 없는지요? 2 비만타쿠미 2018.09.26 116
402 한글html 1 키보드 향기 2020.03.29 922
401 한글 타이틀이 깨져 보입니다. 1 안스가리오 2020.01.06 116
400 표와 div span 4 키보드 향기 2020.04.05 109
399 페이지에 첨부하고 싶은 이미지의 위치에대해 궁금합니다 1 정택희 2017.02.13 277
398 페이지 247 에 있는 Open Challenge 05 의 CSS3로 태그 배치하기를 공부하고 있는데 질문드립니다. 1 file 워니고 2018.03.28 3878
397 테스트 관리자 2019.08.30 171
396 태그와 속성 2 tc0712 2021.09.08 72
395 크롬 오디오 자동재생 관련 질문입니다! 1 ^_^ 2018.09.30 449
394 코드 잘못된 부분을 봐주시면 정말 감사하겠습니다 1 file 입문한 사람 2020.04.01 607
393 캔버스 관련 질문 1 원그리기 2021.08.22 101
392 챕터2 연습문제 8번 김석현 2018.04.22 156
391 챕터 3의 10번 문제 1 컴공과 입문 2018.03.20 125
390 책을 종이책으로 구매했는데 1 ddd 2024.03.21 103
389 책을 마치며 7 은성 2017.04.13 492
388 책 151p 3장 오픈챌린지 문제질문입니다. 3 이상민 2019.07.19 239
387 짝수번 정답 3 idididid 2017.12.24 3136
386 질문입니다 1 1213 2018.03.06 420
385 질문드립니다. 1 ㅇㅇ 2020.06.03 306
384 질문 있습니다. 2 2021.08.19 134
목록
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로