메뉴 건너뛰기

조회 수 154 댓글 2

var commentDiv;

function init() {
    commentDiv = document.getElementById("commentDiv");    
.....
이부분에서 변수선언과 초기화를 따로따로해주셧는대 

그냥 function init()영역 바깥이나 안에 선언과 초기화를 한번에 해주면 제대로 작동이 안되던대 이유가 뭔가요?
예를 들어 
var commentDiv = document.getElementById("commentDiv"); 
function init() {
....
이런식이나
function init() {
var commentDiv = document.getElementById("commentDiv"); 
...
이런식으로요
저렇게 초기화와 선언을 한번에 해주니깐 마우스를 올리고 내렸을때 작동이  안되는대 이유가 궁금합니다.
 

?
  • ?
    관리자3 2019.08.25 14:21

    이상하게 이 질문에 답을 올리면 잘 올라가지 않는데 원인을 아직 잡지 못했습니다. 그래서 궁여지책으로 아래와 같이 답을 드립니다.

     

    -----------------------------------

    변수의 종류에 대해 정확한 공부가 안되어 있어서 지금 어려워 하는 겁니다.(책 268페이지 참고)

    1.함수안에 선언한 변수를 지역 변수라고하고, 이 변수는 함수 밖에서 액세스할수 없어요.
    우선 질문자의 첫 번째 세 줄과 같이한 것이 바로 commenDiv 변수를 지역 변수 로 선언합니다.

    지역 변수는 함수가 끝나면 사라집니다. 그러니까 init()이 불러질 때 생겻다가 init() 끝남과 동시에 사라집니다.

    2. 함수 바깥에 선언된 변수가 전역 변수이니다. 질문자의 두 번째 소스 코드와  같이 하면 전역 변수 commentDIv를 선언합니다.

    전역변수는 한 번 만들어지면 어디서든 사용되고 브라우저가 닫힐 때까지 없어지지 않아요.
    다만 앞의 코드는  init()이 불려지기 전에 그러니까 HTML 페이지가 로딩되고 있는 상태에서
    이 코드(var commentDiv = document.getElementById("commentDiv"); )를 만날 때 바로 실행되고 전역변수가 생깁니다.
    문제는 여기에 있습니다. 이 라인이 실행되는 시점에서 document 객체가 완성되어 있지 않고, id=commentDiv 인 태그가 처리되지 않은 상태라면
    이문장에서(document.getElementById("commentDiv"); ) 오류가 납니다.
    그러니까 이 문장(document.getElementById("commentDiv"); )은 HTML 문서가 완전히 로딩된 후에 실행되어야 합니다.
    그래서 저의 정답은 질문자의 마지가 소스 방법과 같이 하지요

    글로 쓰니 매우 표현이 어렵군요,
     

  • ?
    관리자 2019.08.25 14:42
    변수의 종류에 대해 정확한 공부가 안되어 있어서 지금 어려워 하는 겁니다.(책 268페이지 참고)

    1. 함수안에 선언한 변수를 지역 변수라고하고, 이 변수는 함수 밖에서 액세스할수 없어요.
    우선 아래와 같이한 것이 바로 commenDiv 변수를 지역 변수 로 선언합니다.
    function init() {
    var cmtDiv = document.getElementById('cmtDiv')

    지역 변수는 함수가 끝나면 사라집니다. 그러니까 init()이 불러질 때 생겻다가 init() 끝남과 동시에 사라집니다.
    2. 함수 바깥에 선언된 변수가 전역 변수이니다. 다음과 같이 하면 전역 변수 cmtDIv를 선언합니다.
    var cmtDiv = document.getElementById('cmtDiv');
    function init() {

    전역변수는 한 번 만들어지면 어디서든 사용되고 브라우저가 닫힐 때까지 없어지지 않아요.
    다만 앞의 코드는 init()이 불려지기 전에 그러니까 HTML 페이지가 로딩되고 있는 상태에서
    이 코드(var cmtDiv = document.getElementById('cmtDiv'); )를 만날 때 바로 실행되고 전역변수가 생깁니다.
    문제는 여기에 있습니다. 이 라인이 실행되는 시점에서 document 객체가 완성되어 있지 않고, id=cmtDiv 인 태그가 처리되지 않은 상태라면
    이문장에서(document.getElementById('cmtDiv'); ) 오류가 납니다.
    그러니까 이 문장(document.getElementById('cmtDiv'); )은 HTML 문서가 완전히 로딩된 후에 실행되어야 합니다.
    그래서 저의 정답은 다음과 같이 하지요
    var cmtDiv;

    function init() {
    cmtDiv = document.getElementById('cmtDiv')

    전역변수만 선언해두고
    HTML 문서가 로딩된 후 호출되는 init() 함수 에서 이문장( cmtDiv = document.getElementById('cmtDiv'); )을 실행하는 겁니다.
    글로 쓰니 매우 표현이 어렵군요,

QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18281
303 간단한 질문 드립니다. 1 뚜룹 2018.06.07 535
302 관리자님 안녕하세요 2018.06.12 228
301 오픈챌린지 6장 질문 littlelion 2018.06.20 435
300 오픈챌린지 9장 littlelion 2018.06.20 1002
299 실습문제 6장 5번 littlelion 2018.06.20 780
298 open challenge 6장 1 aoharu 2018.09.15 622
297 예제코드 크롬 브라우저실행 1 2018.09.17 94
296 혹시 예전 서적인 "DHTML + 자바스크립트 프로그래밍"의 예제를 받을 수 있는 방법은 없는지요? 2 비만타쿠미 2018.09.26 116
295 7장 6번문제 질문있습니다. 2 초심자 2018.09.26 340
294 4장 19번 1 .. 2018.09.28 906
293 5장 10번 실습문제 1 익명 2018.09.29 313
292 각 장의 연습문제에 쓰인 사진파일좀 올려주실수있나요? 1 익명 2018.09.29 159
291 크롬 오디오 자동재생 관련 질문입니다! 1 ^_^ 2018.09.30 449
290 4장 실습문제 7번, 9번 1 ehdtn6288 2018.10.01 428
289 실습문제 짝수번 이미지들은 다운할 수 없나요? 공부하면성공한다 2018.10.02 366
288 5장 실습문제 9번 1 file 123 2018.10.03 563
287 3장 151페이지 오픈첼린지3번 문제 답은 어디서 볼 수 있나요? 어려워요 2018.10.07 226
286 안녕하세요 질문드립니다! 2 Hola 2018.10.17 418
285 6장 그림 2번 질문있습니다! 2 1592012 2018.10.19 166
284 오픈 첼린지 9장 질문 있습니다. 4 file muuum 2018.10.21 633
목록
Board Pagination Prev 1 ... 2 3 4 5 6 7 8 9 10 ... 21 Next
/ 21
위로