메뉴 건너뛰기

2017.04.05 16:15

8장 연습문제 8번

조회 수 1362 댓글 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 18281
203 Page 396 script 위치 관련 질문 드립니다 2 질문드립니다 2020.11.05 154
202 p.583 4번 질문드립니다. 6 열심히 공부하는 독자 2020.09.14 287
201 p.524 쿠키 질문드립니다. 2 열심히 공부하는 독자 2020.09.12 71
200 p.469 실습 5번문제 4 열심히 공부하는 독자 2020.08.29 92
199 p.469 6번 질문드립니다. 4 열심히 공부하는 독자 2020.09.08 64
198 p.296 isNaN 함수 1 yamto 2020.12.28 180
197 p.254 3번문제 질문드립니다. 2 열심히 공부하는 독자 2020.08.14 48
196 p.133 질문이요 1 컴퓨터공학생 2020.08.30 67
195 p.133 질문이요 1 컴퓨터공학생 2020.08.30 74
194 open12 질문드립니다. 3 열심히 공부하는 독자 2020.09.08 111
193 open challenge10 관련 질문드립니다 1 궁금해용 2018.05.16 368
192 open challenge 코드 11 hardworking 2017.03.27 1106
191 Open Challenge 와 실습문제 자료 2 김원상 2017.04.29 7446
190 open challenge 6장 1 aoharu 2018.09.15 622
189 open challenge 05 2 hardworking 2017.03.29 2225
188 open 8 질문 2 열심히 공부하는 독자 2020.08.15 62
187 open 10장 1 sigwq 2018.11.27 448
186 localhost 관련 문의 3 소년정 2018.02.20 4039
185 list type 질문이요 2 file 021 2020.05.03 107
184 length 프로퍼티 2 열공이 2022.05.21 59
목록
Board Pagination Prev 1 ... 6 7 8 9 10 11 12 13 14 15 ... 21 Next
/ 21
위로