메뉴 건너뛰기

2017.04.05 16:15

8장 연습문제 8번

조회 수 1361 댓글 5

<script>
var elem = document.getElementById("myBody");
        if(elem == null) alert("body is not made yet");
</script>
</head>
<body id="myBody">

 

부분에서 경고문이 출력되는데

getElementById로 "myBody"(본문에 body)에 대한 객체를 찾지만,

객체가 아직 생성되기 전이기 때문에

elem ==NULL 이되어서

경고가 출력되는 건가요 ?

 

?
  • ?
    황기태 2017.04.05 18:19

    그렇습니다. 잘하는군요.
    브라우저가 HTML 파일을 읽어 DOM 객체를 만들어가는 과정에서 자바스크립트 코드가 실행됩니다.
    그런데 아직 < body> 태그가 브라우저에 의해 읽혀지기 전이고 id 값이 myBody인 body 객체가 만들어지기 전이어서
    getElementById()는 null을 리턴하게 됩니다.

    이 문제를 낸 의도는 자바스크립트 코드의 위치와 실행 과정을 잘 알지 못하면 오류에 빠질 수 있음을 알려주려고 만든 것입니다.

  • ?
    은성 2017.04.05 18:41
    감사합니다! 완벽하게 이해 되었습니다!
  • ?
    은성 2017.04.05 18:44
    그런데 한가지 의문이 듭니다.
    <script>는 어디에나 존재할 수 있다고 배웠습니다.
    body안에도 작성이 가능하구요.

    html은 순서대로 로드하는데,
    만약에 스크립트 코드가 body 안에 있다면 어떻게 되나요?
    그때도 우선순위는 script가 먼저 가지나요 ?
  • profile
    관리자 2017.04.05 18:54
    그건 제가 답변해드리겠습니다.
    모든 태그는 위에서 아래 방향으로, 좌에서 우 방향으로 처리가 됩니다.

    아래와 같이 <body> 태그가 구성되어 있다고 생각해봅시다.

    <body>
    <script>
    var test = document.getElementById("test");

    test.style.backgroundColor = "blue";
    </script>

    <div id="test">
    Test
    </div>
    </body>

    이 경우 <script> 태그 내부에서 찾고자 하는 태그인 <div>태그가 <script> 태그보다 나중에 등장하므로 ,
    document.getElementById("test")는 null을 반환하게 되고 <div> 태그의 배경색은 변하지 않습니다.

    이때 순서를 반대로 해서
    <body>
    <div id="test">
    Test
    </div>

    <script>
    var test = document.getElementById("test");

    test.style.backgroundColor = "blue";
    </script>
    </body>
    와 같이 작성하게 되면, <div> 태그의 배경색이 정상적으로 바뀌는 것을 확인할 수 있습니다. ^^
  • ?
    은성 2017.04.05 18:58
    가지고 있던 의문이 해소되어서 다행입니다!
    코드작성순서도 분명 영향을 끼친다는 거군요!
    감사합니다!!

QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18275
403 자바스크립트에 대해 1 이윤재 2017.01.26 310
402 페이지에 첨부하고 싶은 이미지의 위치에대해 궁금합니다 1 정택희 2017.02.13 277
401 웹 프로그래밍 책 답안지 1 mumu 2017.03.06 14075
400 이미지를 HTML 파일과 같은 폴더에 저장하였는데 왜 이미지가 보이지 않을까요? 1 황기태 2017.03.27 547
399 open challenge 코드 11 hardworking 2017.03.27 1106
398 인코딩, 앵커 1 간구 2017.03.27 160
397 연습문제 답안지 2 vdncnck 2017.03.28 3264
396 open challenge 05 2 hardworking 2017.03.29 2224
395 3장의 실습문제 1 file minju0508 2017.04.02 1334
394 실습문제 7장 2번 질문있습니다 1 jobjob 2017.04.04 1458
393 6장 예제 6-23 1 은성 2017.04.04 317
» 8장 연습문제 8번 5 은성 2017.04.05 1361
391 8장 실습문제 7번 5 은성 2017.04.05 695
390 9장 실습문제 4번 3 은성 2017.04.06 1172
389 10장 오픈챌린지 5 은성 2017.04.07 2247
388 placeholder속성 1 khl 2017.04.08 85715
387 7장 오픈첼린지 1 Bolt 2017.04.11 1071
386 책을 마치며 7 은성 2017.04.13 492
385 ㅠㅠ..질문좀 드리겠습니다.. 1 은성 2017.04.18 3835
384 Open Challenge 와 실습문제 자료 2 김원상 2017.04.29 7446
목록
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로