메뉴 건너뛰기

<!DOCTYPE html>
<html>
<head>
<title>이벤트 객체 전달받기</title>
</head>
<body>
<p id="p">마우스를 올려 보세요</p>
<button onclick="f(event)">클릭하세요</button>
<script>
    function f(e){
        alert(e.type);
    }

    document.getElementById("p").onmouseover = f;
</script>
</body>
</html>

보통 코드를 작성하면 위에서 아래로 읽어서 실행하는 것으로 알고 있는데

<button onclick="f(event)">에서 f(event) 함수를 사용하는데 정의되있기전에 사용하면 원래는 오류를 발생하지 않나요?

document.getElementById("p").onmouseover = f;도 밑에 정의되있는데 왜 <p id="p">가 사용되는지 잘 모르겠습니다.

 

?
  • ?
    관리자 2020.11.05 13:58

    좋은 질문입니다. 질문한 분의 말처럼, 선언된  후 사용되는 것이 원칙이지요.
    이 예제 역시 f() 함수가 선언된 이후에 f() 함수가 사용(호출)되고 있습니다. 다음 설명을 보세요.

    웹페이지가 로딩될 때 아래의 부분을 만나면
    <button onclick="f(event)">클릭하세요</button>

    함수 f()를 호출하는 것이 아닙니다. onclick 속성에 그저 "f(event)"라는 코드를 등록하지요. 함수호출문이라는 것조차 해석하지 않습니다.
    이것이 바로 스크립트 언어의 특징입니다. 실행 중에 오류가 있으면 실행이 중단되는 것이 스크립트 언어의 특징입니다.

    그러고나서 내려가면 <script> 태그를 만나고 그곳에 함수 f()의 선언문을 보게 됩니다. 이제 여기서 함수 f()의 존재를 기억해 두겠지요.
    그리고 웹페이지의 로딩이 완료되고 화면에는 웹 페이지가 출력됩니다.
    그리고 사용자가 버튼을 누르지 않으면 함수 f()가 호출될 일도 없습니다.
    만일 사용자가 버튼을 누르면 그때 버튼의 onclick에 등록해둔 코드를 실행합니다.
    등록해둔 코드는 f(event)이고 함수 f()를 호출합니다.
    함수 f()가 이전에 웹페이지 로딩시에 인지되었고, 함수 f()가 자연스럽게 실행됩니다.

  • ?
    질문드립니다 2020.11.09 13:19
    아 감사합니다 확실히 이해가됬습니다

QnA

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 읽어주세요! 연습문제 및 실습문제 정답 공개에 관한 공지입니다. file 관리자 2017.06.20 18277
223 간단한 질문입니다 1 ㅇㅇ 2018.03.04 267
222 간단한 질문 드립니다. 1 뚜룹 2018.06.07 535
221 각 장의 연습문제에 쓰인 사진파일좀 올려주실수있나요? 1 익명 2018.09.29 158
220 ㅠㅠ..질문좀 드리겠습니다.. 1 은성 2017.04.18 3835
219 [명품 html5+ css3+ javascript 웹 프로그래밍 수정판] 1장 실습문제 4번 질문합니다... 2 file 나능냐공도리 2021.04.17 918
218 [개정판] p.357 sibling 에 대한 설명 및 그림 8-7 1 질문 2022.09.02 59
217 z-index 관련 질문 번역봇 2020.10.13 63
216 webgl 2차원. 1 궁금해요 2022.10.10 134
215 value 속성 1 열심히 공부하는 독자 2020.09.04 48
214 URL 과 IP 주소 2 tc0712 2021.09.14 120
213 u+ 공유기 포트포워딩 방법 1 ge님 2018.03.30 758
212 timerID값이 null인 이유 1 열공이 2022.05.26 602
211 target프로퍼티 질문(페이지 428쪽) 2 한성이 2022.08.14 47
210 Sublime Text, VS code IDE설명 update바랍니다 1 삼오칠 2023.04.15 86
209 SRC와 SRDOC의 차이를 여쭙고 싶습니다. 입문한 사람 2020.04.07 48
208 span과 text-align : center; 에 관한 문제입니다. file 2019.10.15 279546
207 setTimeout 질문드립니다. 3 file 웹프공부중 2020.06.09 130
206 r/w는 무슨 뜻인가요? 1 ㅇㅁㅇㅈ 2021.12.22 393
205 placeholder속성 1 khl 2017.04.08 85722
204 page 46 마우스 올릴시 이미지 출력 2 file 공부중 2020.09.10 323
목록
Board Pagination Prev 1 ... 5 6 7 8 9 10 11 12 13 14 ... 21 Next
/ 21
위로