메뉴 건너뛰기

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 18274
383 7장 10번문제 1 학섕 2017.07.12 1868
382 자바스크립트의 컴파일오류 2 1234 2018.12.22 1843
381 61 page 실습문제 1번 오류찾기 2 궁금이 2020.02.15 1757
380 7장에 실습문제 4번 질문 1 asd123 2017.11.05 1634
379 실습문제 3장 2번, 4장 8번 질문 다시 올려요. littlelion 2018.04.20 1586
378 5장 연습문제 질문 1 5장 연습문제 질문 2019.04.05 1507
377 실습문제 7장 2번 질문있습니다 1 jobjob 2017.04.04 1458
» 8장 연습문제 8번 5 은성 2017.04.05 1361
375 3장의 실습문제 1 file minju0508 2017.04.02 1334
374 2장 이론문제 3번 1 알고싶어요 2021.03.14 1332
373 7장 이론문제 3번 이의제기 합니다. 3 file 혁999 2017.12.10 1279
372 7장에 연습문제에 있는 실습문제 질문 1 student 2017.05.07 1261
371 9장 오픈챌린지 답이 너무 궁금합니다. 1 범이 2017.05.10 1253
370 3장 open challenge 질문해봅니다 6 진혁 2018.01.30 1247
369 9장 실습문제 10번 2 왜죠 ㅠㅠ 2021.01.24 1204
368 9장 실습문제 4번 3 은성 2017.04.06 1172
367 명품 html5+ css3+ javascript 웹 프로그래밍 수정판 문제 실행 오류 문의 1 file mikael 2021.04.14 1159
366 10장 실습문제5번 질문입니다, 1 asdfdef 2019.08.30 1154
365 8장 OPEN Challlenge 질문 있습니다. 1 컴퓨터공학13 2018.05.18 1150
364 9장 2번 질문있습니다. 웹프로그래밍 2017.05.28 1136
목록
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로