9. Event 객체


  이벤트란 간단히 말하자면, 사용자의 행위(Action)를 말한다. 즉, 버튼을 누르거나, Text에 글자를 쳐 넣거나, 브라우저가 새로운 문서를 읽어 들이거나, 브라우저를 닫거나 하는 것들이 바로 이벤트인 것이다.

  초기에 웹 환경, 정확히 말하자면, HTML에서는 이러한 것이 없었다. 그래서, 사용자의 입력에 반응하지 못함에 따라 웹 서버와 네트워크에 부하를 주었던 것이다. 그러한 문제 때문에 자바스크립트가 추가되면서 이러한 문제점을 줄여주었던 것이다.

  자바스크립트를 HTML문장에 사용할 수 있게 되면서, 사용자의 행동에 따라 적절한 조치를 취할 수 있게 됨에 따라 HTML 문서의 내용만을 단순히 보여주는 브라우저환경을 벗어날 수 있게 된 것이다.

  즉, 자바스크립트가 이벤트를 처리(Handle)하게 됨에 따라 HTML문서가 보다 동적인(Dynamic) 페이지가 될 수 있었다. 대부분 이벤트가 발생하면, 이 이벤트를 처리(Handle)할 수 있는 함수를 만들어서 해당 이벤트에 대응하게 하는데, 이렇게 이벤트와 처리함수를 묶어주는 것을 이벤트 핸들러(Event Handler)라고 부른다.

  다음은 이벤트의 종류와 그에 대한 설명이다.

이벤트명발생대상설 명
Abortimage이미지를 로딩하다가 멈추었을 때
Blurwindow, form element입력 포커스가 이동할 때
Changetext, textarea, select내용이 변경되었을 때
Clickbutton, radio, checkbox, submit, reset마우스가 눌렸을 때
DblClickbutton, radio, checkbox, submit, reset마우스가 두번눌렸을 때
DragDropwindow마우스를 누른 상태로 움직였을 때
Errorimage, window문서나 이미지를 로딩하다 멈췄을 때
Focuswindow, form element입력 포커스를 받았을 때
KeyDowndocument, image, link, text키보드로 값을 입력했을 때
KeyPressdocument, image, link, text키보드가 눌렸을 때
KeyUpdocument, image, link, text키보드가 눌렸다 놓았을 때
Loaddocument문서를 로딩을 완료했을 때
MouseDowndocument, button, link마우스가 눌렸을 때
MouseMoveall마우스가 움직일 때
MouseOutimage map, link마우스가 빠져나갈 때
MouseOverlink마우스 포인터가 올라왔을 때
MouseUpdocument, button, link마우스를 눌렀다 놓았을 때
Movewindow브라우저를 이동시킬 때
Resetformform 태그 중 reset버튼을 눌렀을 때
Resizewindow브라우저의 사이즈를 변경할 때
Selecttext, textarea입력창을 선택했을 때
Submitformform값을 전송할 때
Unloaddocument브라우저가 현재 문서에서 빠져나갈 때


  위의 이벤트는 앞에서 말한 대로 사용자가 발생을 시킨다. 그럼 그 이벤트에 해당하는 함수를 어떻게 대응시키는가 배워야 하겠다. 즉, 이벤트 핸들러를 사용하는 방법부터 알아보자.일반적으로 이벤트 핸들러는 이벤트명 앞에 단순히 on을 붙이면 된다. 즉, Click 이벤트를 잡아내고 싶으면 onClick이라고 하면 Click이벤트 핸들러가 되는 것이다. 이벤트는 특정한 HTML요소 즉, HTML Tag에서 발생되는 것이기 때문에 다음과 같이 표기한다.

<TAG eventHandler="처리할 실제함수명();">
  실제 예로, 간단히 Form Tag중에 Button을 예로 들면,

<INPUT TYPE="button" VALUE="Click Me" onClick="func();">
  와 같이 사용하면 된다. 이렇게 이벤트 핸들러에는 함수나 다른 자바스크립트 코드가 올 수 도 있다. 자바스크립트 코드가 여러 개 올 경우에는 반드시 세미콜론(;)을 넣어주어야 하지만, 위의 예처럼 하나의 문장인 경우는 세미콜론을 생략할 수도 있다.

  하나의 HTML 요소에 여러개의 이벤트 핸들러를 지정할 수도 있다.

<TAG onClick="alert('Click')" onFocus="alert('Focus')">

- Last Update : 2001.7.3 by Deadfire(http://www.deadfire.net)

Javascript 강좌
들어가기
Javascript란?
작동 방식
장 단 점
기 초
     - HTML문서에추가하기
     - 최초 예제
     - 함수사용하기
     - 기본 함수
문 법
     - 변 수
     - 연 산
     - 조 건 문
     - 반 복 문
     - 사용자함수
객 체
     - Object란?
     - 속성과 함수
     - 객체의 생성과사용
내장 객체
     - Date
     - Math
     - String
     - Array
     - Boolean
     - Function
     - Argument
     - Number
     - Global
     - 기 타
     - with / delete
Event 객체
네비게이터 객체
     - 네비게이터객체구조
     - 객체 접근 방법
     - navigator
     - window
     - location
     - history
     - document
     - form
     - form elements
Frame 객체
기 타
     - Animation
     - Audio
마치며

Copyright ⓒ 1997 ~, Deadfire Program Master