-문제
6장 그림 6-2번에서 스크립트 태그를 헤드로 옮기면 원하는 결과가 나오지 않습니다. 거기서 var ret=document.getElementById("result")만 바디에 따로 스크립트를 만들어서 넣으면 오류가 원하는 결과가 나오는데요.
-질문
1. 왜 스크립트태그를 전부 헤드로 올리면 원하는 결과값이 나오지 않는건가요?
2. 혹시 바디태그에 result아이디가 만들어지기전이라서 그런거라면 var ret=document.getElementById("result")만 따로 바디로 내렸을땐 왜 결과가 제대로 나오는건가요? promptEX()에서 result.innerHTML에서 문제가 발생해야 하는것 아닌가요?
궁금한 것에 적극적인 질문을 주신 것 환영합니다.
프로그램이 실행되는과정과 전역변수를 이해하면 현재 상황을 이해할 수있을것 같군요.
우선 브라우저는 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>에 의해 형성되는 객체를 가리키고 있습니다.
이상입니다.