메뉴 건너뛰기

2019.12.04 00:03

8장 실습 문제 5번

조회 수 214 댓글 3

<script>
    var imgArray = document.getElementsByTagName("img");
    for(var i=0; i<imgArray.length; i++) {
        var obj = imgArray[i];
        obj.style.zIndex = i;
        obj.style.left = "20px";
        obj.style.top = "20px";

        obj.onclick = change;
        //obj.onclick = change();하면 안먹는데 이유가 뭘까요?
    }
    function change() {
        for(var i=0; i<imgArray.length; i++) {
            var obj = imgArray[i];
            obj.style.zIndex++;
            obj.style.zIndex %= imgArray.length;
            // zIndex = zIndex % imgArray.length 이것을 왜 해야하는지, 왜 %=인지 모르겠습니다.
        }
    }
</script>

?
  • ?
    관리자 2019.12.04 10:27

    1.
    obj.onclick = change();의 의미는 change() 함수를 호출하고 그 결과 값을 obj.onclock에 넣는 것입니다.
    그러므로 클릭할 때 함수 change()가 실행되도록 하겠다면 obj.onclick = change; 로 해서 함수의 이름(실제로는 주소)를 등록해야 합니다.
    2.
    하나의 이미지를 밑으로 내리기 위해서는 모든 이미지의 zIndex를 증가시키고
    제일 큰 zIndex를 가진 이미지 즉 제일 위에 있는 이미지의 zIndex를 0으로 만들기 위한 것입니다.
    만일 이미지가 총 8개 있다면 처음에는 zIndex가 다음과 같지요
    0 1 2 3 4 5 6 7

    제일 위에 것이 아래로 내려가려면 모든 이미지의 zIndex를 증가시키면
    1 2 3 4 5 6 7 8
    이 될 것입니다. 그런데 이미지의 크기 length가 8이므로
    제일 위의 이미지의 zIndex는 8이고 이에 다음 코드가 실행되면
    obj.style.zIndex %= imgArray.length;

    8 % 8 = 0이 됩니다.
    나머지 7개의 zIndex는 1~7이므로 8로 나눈 나머지는 그대로 1~7로 있게 됩니다. 결과적으로
    다시 이미지들의 zIndex는 아래와 같이 됩니다.
    0 1 2 3 4 5 6 7

  • ?
    아리 2019.12.04 22:49
    2번은 이해했습니다. 감사합니다.
    1번은 체인지 함수를 선언하지 않고 change를 썼다면 change 가 무엇을 의미하는지요?
  • ?
    관리자 2019.12.15 23:13
    질문이 또 올라왔는지 못 보아서 답이 늦었습니다.
    change 는 함수의 이름인데 곧 함수의 주소입니다.
    이렇게 설명하면 C 언어를 배운 학생이라면 좀 더 쉽게 이해하겟지만, 함수의 주소를 주는 것이 또 어떤 의미인지 의문이 들 것 입니다.
    자바스크립트에서
    obj.onclick = change; 은
    onclick 리스너로 change 함수를 등록하는 작업이라고 생각하면 됩니다.

QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18281
323 385p 8장 실습문제 07번 질문입니다. 1 12345 2019.08.16 616
322 코드 잘못된 부분을 봐주시면 정말 감사하겠습니다 1 file 입문한 사람 2020.04.01 607
321 7장 실습문제 1번 질문 있습니다. 7 jonjsin 2017.11.09 603
320 timerID값이 null인 이유 1 열공이 2022.05.26 602
319 저자님 367페이지 질문있습니다~~ 1 file 칼잡이최제잘 2018.02.19 591
318 6장 7번 좀 알려주세요 ㅜㅜ 1 어려워여 2020.06.14 589
317 9장 onblur onfocus 활용 실습문제 2번 웹린이 2018.05.21 568
316 4장 6번문제 물어볼려고합니다 1 배재한 2019.04.16 566
315 5장 실습문제 9번 1 file 123 2018.10.03 563
314 교과서 13장 연습문제 1 알고싶어요 2021.05.29 553
313 9장 4번 질문있습니다. 웹프로그래밍 2017.05.28 551
312 이미지를 HTML 파일과 같은 폴더에 저장하였는데 왜 이미지가 보이지 않을까요? 1 황기태 2017.03.27 547
311 바닐라js 란 것에 대해 질문이 있습니다. 2 muuum 2018.11.01 546
310 1장 test1, 2, 3 파일 2 열공중 2020.03.07 542
309 간단한 질문 드립니다. 1 뚜룹 2018.06.07 535
308 이 책을 다 본 뒤 어떤 공부를 더 하는게 좋을까요? 1 file muuum 2018.10.31 526
307 8장 실습문제 8번 질문드립니다. 3 메론 2018.11.11 525
306 명품 HTML5+ 수정판 2장 4번 문제 문의 1 file mikael 2021.04.14 520
305 HTML5+CSS3+Javascript 웹 프로그래밍[수정판] 4 file Jenny 2021.09.25 519
304 오픈 챌린지 6장 1 ㄱㄷㄱㄷ 2018.04.22 514
목록
Board Pagination Prev 1 ... 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로