메뉴 건너뛰기

조회 수 166 댓글 2

-문제

6장 그림 6-2번에서 스크립트 태그를 헤드로 옮기면 원하는 결과가 나오지 않습니다. 거기서 var ret=document.getElementById("result")만 바디에 따로 스크립트를 만들어서 넣으면 오류가 원하는 결과가 나오는데요.

-질문

1. 왜 스크립트태그를 전부 헤드로 올리면 원하는 결과값이 나오지 않는건가요?

2. 혹시 바디태그에 result아이디가 만들어지기전이라서 그런거라면 var ret=document.getElementById("result")만 따로 바디로 내렸을땐 왜 결과가 제대로 나오는건가요? promptEX()에서 result.innerHTML에서 문제가 발생해야 하는것 아닌가요?

?
  • ?
    관리자 2018.10.19 15:01

    궁금한 것에 적극적인 질문을 주신 것 환영합니다.

    프로그램이 실행되는과정과 전역변수를 이해하면 현재 상황을 이해할 수있을것 같군요.
    우선 브라우저는 HTML 문서를 위에서 부터 하나씩 실행한다는 사실을 염두에 두고 아래 글을 읽어 보세요.

    1. var result=document.getElementById("result") 문장이
    <div id="result"></div> 보다 앞에 있게 되면 id 속성이 "result"인 태그를 발견할 수 없어서 오류가 나는 겁니다.

    2. 다음은 자바스크립트 함수의 선언입니다.
    function promptEX() {
    ...
    }
    선언된 함수는 웹페이지가 사라질 때까지 그 생명을 가지고 있고, 어디서든지 호출될 수 있습니다.

    3. var result=document.getElementById("result") 문장을 <div id="result"></div> 보다 아래에 두면
    브라우저는 id 속성이 "result"인 태그를 발견하는데 문제가 없지요.
    그리고 var result=document.getElementById("result") 문장이 실행되면 result 라는 전역변수가 생기고 이 변수는 <div id="result"></div>에 의해 형성되는 객체(8장에서 설명할 DOM 객체)를 가리키고 있습니다.
    전역변수는 웹 페이지가 사라질 때까지 존재하는 변수입니다.
    그리고 나서 사용자가 웹 페이지에 버튼을 누를 때 promptEX() 함수가 호출되고,
    이 함수에 전역변수 result 를 접근하는데는 문제가 없지요. 또한 전역변수 result 는 여전히 <div id="result"></div>에 의해 형성되는 객체를 가리키고 있습니다.

    이상입니다.

  • ?
    글쓴이 2018.10.19 18:38
    감사합니다 ㅎㅎ

QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18281
323 연습문제 짝수번 정답 기러기 2018.04.20 760
322 실습문제 3장 2번, 4장 8번 질문 다시 올려요. littlelion 2018.04.20 1587
321 예제5-9와 예제 5-14 3 궁금해요! 2018.04.20 127
320 자바스크립트 sort에 대해 궁금해요! 1 file 노하람 2018.04.21 236
319 예제 3-1 1 새싹 2018.04.21 91
318 예제 3-2 2 새싹 2018.04.21 148
317 예제 2-9 1 새싹 2018.04.22 86
316 예제 3-4 1 새싹 2018.04.22 158
315 챕터2 연습문제 8번 김석현 2018.04.22 156
314 오픈 챌린지 6장 1 ㄱㄷㄱㄷ 2018.04.22 514
313 예제3-8 1 새싹 2018.04.22 123
312 예제 3-11 1 새싹 2018.04.23 301
311 구버전 책을 구입해버렸어요.. 3 구닥 2018.05.07 333
310 실습문제 5장 3번 254p 1 RVQ 2018.05.10 332
309 open challenge10 관련 질문드립니다 1 궁금해용 2018.05.16 368
308 8장 OPEN Challlenge 질문 있습니다. 1 컴퓨터공학13 2018.05.18 1150
307 9-8 실습 문제 질문있습니다. 1 웹프박살 2018.05.20 430
306 9장 onblur onfocus 활용 실습문제 2번 웹린이 2018.05.21 569
305 HTML을 열심히 공부중인 학생입니다 3 열심히 하자 2018.05.30 1962
304 인라인 프레임 많이 사용하나요? 1 html 2018.06.02 153
목록
Board Pagination Prev 1 ... 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로