메뉴 건너뛰기

2020.05.14 00:47

Image 객체

조회 수 127 댓글 2

<!DOCTYPE html>

<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="utf-8" />
    <title></title>
    <style>
        img {
            height: 50px;
            width: 50px;
            margin: 0px;
        }

        table {
            border-collapse: collapse;
            border: 1px solid blue;
            padding: 0px;
        }

        td {
            border: 1px solid blue;
            width: 50px;
            height: 50px;
            padding: 0px;
        }
    </style>
</head>
<body onload="load()">
    <h3>마우스 클릭 연습</h3>
    <hr />
    <script>
        document.write("<table>");
        for (var i = 0; i < 100; i++) {
            if (i / 10 == 0) {
                document.write("<tr>")
            }
            document.write("<td id='td" + i + "'>");
            document.write("</td>");
            if (i % 10 == 9) {
                document.write("</tr>");
            }
        }
        document.write("</table>");

        function load() {
            var img = new Image();
            img.src = "banana.jpg";
            img.onload = function () {
                img.width = "50px";
                img.height = "50px";
            }
            img.onclick = function () {
                var ran = Math.floor(Math.random() * 100);
                var td = document.getElementById("td" + ran);
                td.appendChild(img);
            }

            var ran = Math.floor(Math.random() * 100);
            var td = document.getElementById("td" + ran);
            td.appendChild(img);
        }
    </script>
</body>
</html>

 

09 오픈 첼린지 문제를 위와 같이 풀었습니다.

푸는 도중에 의문이 생겼습니다.

원래 의도는 Image 객체를 클릭하면 해당 td의 자식 객체를 removeChild로 없애준 후에 랜덤으로 다른 td에 자식을 더해주려고 했습니다. (onclick 에 리스너 등록한 부분)

근데 없애지 않았는데도 이미지를 클릭하면 원래 있던 자리에서 다른 자리로 그냥 옮겨가더군요.

 

1. new Image()로 생성시킨 객체는 한 DOM 객체에만 사용할 수 있어서 다른 객체에 부여하면 옮겨가는 건가요??

2. 만약 그렇다면 자바스크립트로 생성시킨 객체들은 모두 한 DOM 객체에만 사용할 수 있는지 아니면 new Image() 객체만 그런건지??

?
  • ?
    관리자 2020.05.14 10:36
    좋은 질문입니다.
    1. 현재 new Image()로 생성한 객체가 한 개 뿐이지요.
    2. 하나의 DOM 객체는 당연히 여러 부모를 가질 수 없습니다. 이렇게 된다면 Image 객체는 누구의 자식일까요? 그리고 화면의 어디에 출력될까요? 당연히 한 부모의 자식입니다.
    그래서 DOM 객체의 부모를 옮기면 원래 부모에서 떨어져 나와 새로운 부모의 자식이 됩니다.
    3. Image 객체 뿐아니라 모든 DOM 객체도 동일합니다.

    지금 이 질문은 자바나 C#, C/C++ 등 다른 프로그램을 작성할 떄도 동일하게 만날 수 있는 문제이라서 좋은 질문이라고 하는 겁니다.
  • ?
    ㅇㅇ 2020.05.14 23:47
    감사합니다!!! 단번에 이해했습니다
    답변 감사합니다~~~!~!!

QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18330
243 명품 html5+ 수정판 css3+ javascript 웹 프로그래밍 실습문제 이미지 파일 어디서 다운 받아요? 1 미카엘 2021.01.14 736
242 명품 HTML5+ 수정판 2장 4번 문제 문의 1 file mikael 2021.04.14 520
241 명품 html5+ css3+ javascript 웹 프로그래밍 수정판 문제 실행 오류 문의 1 file mikael 2021.04.14 1159
240 마우스오버기능 이용해서 플레이되는 오디오 제작중인데요 1 file 성북동뽀글이 2019.01.25 292
239 따옴표를 4중 5중으로 사용하는 방법에 대해 여쭙고 싶습니다. 입문한 사람 2020.04.07 40
238 답안이 없는 책이라니 ;;; 2 이준석 2018.11.01 408
237 그림이 안떠요(실습문제 4장 7번) 2 file 초보자 2020.04.27 684
236 궁금한점이 있습니다. 1 hayio 2020.06.17 80
235 궁금한게 있어요 마맘마 2019.04.19 184
234 구버전 책을 구입해버렸어요.. 3 구닥 2018.05.07 333
233 교제 254페이지 1 쿠웨이트 2022.04.12 84
232 교재425page 9장 오픈챌린지 질문입니다. [재수정해서 올립니다.] 3 ㅁㄴㅇㄻㄴㅇㄹ 2019.08.20 770
231 교재403page 예제9-8 코드 질문입니다. 1 asdf 2019.08.19 101
230 교재 468page 실습문제 2-2번 질문입니다. 3 세린 2019.08.23 255
229 교재 413page 질문입니다. 1 ㅁㅇㄻㄴㅇㄹ 2019.08.20 98
228 교재 225page 예제5-8 질문입니다. 1 ㅇㅅㅁ 2019.09.01 141
227 교과서 13장 연습문제 1 알고싶어요 2021.05.29 553
226 관리자님 안녕하세요 2018.06.12 228
225 계산기 문제 변형 문의 file Mikael 2022.12.13 56
224 게시판QnA질문입니다. 4 file asdf 2019.08.30 182
목록
Board Pagination Prev 1 ... 4 5 6 7 8 9 10 11 12 13 ... 21 Next
/ 21
위로