jQuery-이벤트 처리

이벤트를 사용하여 동적 웹 페이지를 만들 수 있습니다. 이벤트는 웹 응용 프로그램에서 감지 할 수있는 작업입니다.

다음은 예제 이벤트입니다-

  • 마우스 클릭
  • 웹 페이지 로딩
  • 요소 위로 마우스 가져 가기
  • HTML 양식 제출
  • 키보드 등의 키 입력

이러한 이벤트가 트리거되면 사용자 지정 함수를 사용하여 이벤트로 원하는 작업을 거의 수행 할 수 있습니다. 이러한 사용자 지정 함수는 이벤트 처리기를 호출합니다.

바인딩 이벤트 핸들러

jQuery 이벤트 모델을 사용하여 DOM 요소에 이벤트 핸들러를 설정할 수 있습니다. bind() 다음과 같이 방법-

<html>
   <head>
      <title>The jQuery Example</title>
      <script type = "text/javascript" 
         src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
      </script>
		
      <script type = "text/javascript" language = "javascript">
         $(document).ready(function() {
            $('div').bind('click', function( event ){
               alert('Hi there!');
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below to see the result:</p>
		
      <div class = "div" style = "background-color:blue;">ONE</div>
      <div class = "div" style = "background-color:green;">TWO</div>
      <div class = "div" style = "background-color:red;">THREE</div>
   </body>
</html>

이 코드는 나누기 요소가 클릭 이벤트에 응답하도록합니다. 이후 사용자가이 부서 내부를 클릭하면 경고가 표시됩니다.

이것은 다음 결과를 생성합니다-

bind () 명령의 전체 구문은 다음과 같습니다.

selector.bind( eventType[, eventData], handler)

다음은 매개 변수에 대한 설명입니다.

  • eventType− 클릭 또는 제출과 같은 JavaScript 이벤트 유형을 포함하는 문자열. 이벤트 유형의 전체 목록은 다음 섹션을 참조하십시오.

  • eventData − 이것은 선택적 매개 변수이며 이벤트 핸들러로 전달 될 데이터 맵입니다.

  • handler − 이벤트가 발생할 때마다 실행되는 기능.

이벤트 처리기 제거

일반적으로 이벤트 핸들러가 설정되면 페이지의 남은 수명 동안 계속 유효합니다. 이벤트 핸들러를 제거하고 싶을 때 필요할 수 있습니다.

jQuery는 unbind()종료 이벤트 핸들러를 제거하는 명령. unbind ()의 구문은 다음과 같습니다.

selector.unbind(eventType, handler)

or 

selector.unbind(eventType)

다음은 매개 변수에 대한 설명입니다.

  • eventType− 클릭 또는 제출과 같은 JavaScript 이벤트 유형을 포함하는 문자열. 이벤트 유형의 전체 목록은 다음 섹션을 참조하십시오.

  • handler − 제공된 경우 제거 할 특정 리스너를 식별합니다.

이벤트 유형

Sr. 아니. 이벤트 유형 및 설명
1

blur

요소가 포커스를 잃을 때 발생합니다.

2

change

요소가 변경 될 때 발생합니다.

click

마우스를 클릭 할 때 발생합니다.

4

dblclick

마우스를 두 번 클릭하면 발생합니다.

5

error

로드 또는 언로드 등에서 오류가있을 때 발생합니다.

6

focus

요소가 포커스를 받으면 발생합니다.

7

keydown

키를 누를 때 발생합니다.

8

keypress

키를 눌렀다 놓을 때 발생합니다.

9

keyup

키를 놓을 때 발생합니다.

10

load

문서가로드 될 때 발생합니다.

11

mousedown

마우스 단추를 누를 때 발생합니다.

12

mouseenter

마우스가 요소 영역에 들어갈 때 발생합니다.

13

mouseleave

마우스가 요소 영역을 벗어날 때 발생합니다.

14

mousemove

마우스 포인터가 움직일 때 발생합니다.

15

mouseout

마우스 포인터가 요소 밖으로 이동할 때 발생합니다.

16

mouseover

마우스 포인터가 요소 위로 이동할 때 발생합니다.

17

mouseup

마우스 단추를 놓을 때 발생합니다.

18

resize

창 크기를 조정할 때 발생합니다.

19

scroll

창이 스크롤 될 때 발생합니다.

20

select

텍스트를 선택하면 발생합니다.

21

submit

양식이 제출 될 때 발생합니다.

22

unload

문서가 언로드 될 때 발생합니다.

이벤트 객체

콜백 함수는 단일 매개 변수를 사용합니다. 핸들러가 호출되면 JavaScript 이벤트 객체가 전달됩니다.

이벤트 객체는 종종 불필요하며 매개 변수가 생략됩니다. 일반적으로 핸들러가 트리거 될 때 수행해야하는 작업을 정확히 알기 위해 핸들러가 바인드 될 때 충분한 컨텍스트를 사용할 수 있지만 액세스해야하는 특정 속성이 있습니다.

이벤트 속성

Sr. 아니. 속성 및 설명
1

altKey

이벤트가 트리거 될 때 Alt 키를 눌렀 으면 true로 설정하고 그렇지 않으면 false로 설정합니다. Alt 키는 대부분의 Mac 키보드에서 Option으로 표시됩니다.

2

ctrlKey

이벤트가 트리거 될 때 Ctrl 키를 눌렀 으면 true로 설정하고 그렇지 않으면 false로 설정합니다.

data

핸들러가 설정 될 때 bind () 명령에 두 번째 매개 변수로 전달 된 값 (있는 경우).

4

keyCode

keyup 및 keydown 이벤트의 경우 눌린 키를 반환합니다.

5

metaKey

이벤트가 트리거 될 때 Meta 키를 눌렀 으면 true로 설정하고 그렇지 않으면 false로 설정합니다. Meta 키는 PC의 경우 Ctrl 키이고 Mac의 경우 Command 키입니다.

6

pageX

마우스 이벤트의 경우 페이지 원점에서 상대적인 이벤트의 수평 좌표를 지정합니다.

7

pageY

마우스 이벤트의 경우 페이지 원점에서 상대적인 이벤트의 수직 좌표를 지정합니다.

8

relatedTarget

일부 마우스 이벤트의 경우 이벤트가 트리거 될 때 커서가 떠났거나 입력 한 요소를 식별합니다.

9

screenX

마우스 이벤트의 경우 화면 원점을 기준으로 이벤트의 수평 좌표를 지정합니다.

10

screenY

마우스 이벤트의 경우 화면 원점을 기준으로 이벤트의 수직 좌표를 지정합니다.

11

shiftKey

이벤트가 트리거 될 때 Shift 키를 눌렀 으면 true로 설정하고 그렇지 않으면 false로 설정합니다.

12

target

이벤트가 트리거 된 요소를 식별합니다.

13

timeStamp

이벤트가 생성 된 타임 스탬프 (밀리 초)입니다.

14

type

모든 이벤트에 대해 트리거 된 이벤트 유형 (예 : 클릭)을 지정합니다.

15

which

키보드 이벤트의 경우 이벤트를 발생시킨 키의 숫자 코드를 지정하고 마우스 이벤트의 경우 눌린 버튼을 지정합니다 (왼쪽은 1, 중간은 2, 오른쪽은 3).

<html>
   <head>
      <title>The jQuery Example</title>
      <script type = "text/javascript" 
         src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
      </script>
		
      <script type = "text/javascript" language = "javascript">
         $(document).ready(function() {
            $('div').bind('click', function( event ){
               alert('Event type is ' + event.type);
               alert('pageX : ' + event.pageX);
               alert('pageY : ' + event.pageY);
               alert('Target : ' + event.target.innerHTML);
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below to see the result:</p>
		
      <div class = "div" style = "background-color:blue;">ONE</div>
      <div class = "div" style = "background-color:green;">TWO</div>
      <div class = "div" style = "background-color:red;">THREE</div>
   </body>
</html>

이것은 다음 결과를 생성합니다-

이벤트 방법

이벤트 객체에서 호출 할 수있는 메소드 목록이 있습니다-

Sr. 아니. 방법 및 설명
1 preventDefault ()

브라우저가 기본 작업을 실행하지 못하도록합니다.

2 isDefaultPrevented ()

이 이벤트 객체에서 event.preventDefault ()가 호출되었는지 여부를 반환합니다.

stopPropagation ()

부모 요소에 대한 이벤트 버블 링을 중지하여 부모 처리기에서 이벤트 알림을받지 못하도록합니다.

4 isPropagationStopped ()

이 이벤트 객체에서 event.stopPropagation ()이 호출되었는지 여부를 반환합니다.

5 stopImmediatePropagation ()

나머지 핸들러의 실행을 중지합니다.

6 isImmediatePropagationStopped ()

이 이벤트 객체에서 event.stopImmediatePropagation ()이 호출되었는지 여부를 반환합니다.

이벤트 조작 방법

다음 표는 중요한 이벤트 관련 방법을 나열합니다.

Sr. 아니. 방법 및 설명
1 bind (유형, [데이터], fn)

일치하는 각 요소에 대해 하나 이상의 이벤트 (예 : 클릭)에 핸들러를 바인딩합니다. 사용자 지정 이벤트를 바인딩 할 수도 있습니다.

2 off (이벤트 [, 선택기] [, 핸들러 (eventObject)])

이것은 라이브와 반대되는 작업을 수행하며 바인딩 된 라이브 이벤트를 제거합니다.

hover (over, out)

예를 들어 개체에서 마우스를 켜고 끄는 등 호버링을 시뮬레이션합니다.

4 on (이벤트 [, 선택기] [, 데이터], 핸들러)

현재 및 미래의 모든 일치 요소에 대해 핸들러를 이벤트 (예 : 클릭)에 바인딩합니다. 사용자 지정 이벤트를 바인딩 할 수도 있습니다.

5 one (유형, [데이터], fn)

핸들러를 하나 이상의 이벤트에 바인딩하여 일치하는 각 요소에 대해 한 번 실행합니다.

6 준비 (fn)

DOM이 순회 및 조작 될 준비가 될 때마다 실행할 함수를 바인딩합니다.

7 트리거 (이벤트, [데이터])

일치하는 모든 요소에서 이벤트를 트리거합니다.

8 triggerHandler (이벤트, [데이터])

요소에 대한 모든 바인딩 된 이벤트 처리기를 트리거합니다.

9 바인딩 해제 ([유형], [fn])

이것은 bind의 반대를 수행하며 일치하는 각 요소에서 바인딩 된 이벤트를 제거합니다.

이벤트 도우미 방법

jQuery는 또한 이벤트를 트리거하여 위에서 언급 한 모든 이벤트 유형을 바인딩하는 데 사용할 수있는 이벤트 도우미 함수 세트를 제공합니다.

트리거 방법

다음은 모든 단락에서 흐림 이벤트를 트리거하는 예입니다.

$("p").blur();

바인딩 방법

다음은 바인딩하는 예입니다. click 모든 <div> 이벤트 −

$("div").click( function () { 
   // do something here
});
Sr. 아니. 방법 및 설명
1

blur( )

일치하는 각 요소의 흐림 이벤트를 트리거합니다.

2

blur( fn )

일치하는 각 요소의 흐림 이벤트에 함수를 바인딩합니다.

change( )

일치하는 각 요소의 변경 이벤트를 트리거합니다.

4

change( fn )

일치하는 각 요소의 변경 이벤트에 함수를 바인딩합니다.

5

click( )

일치하는 각 요소의 클릭 이벤트를 트리거합니다.

6

click( fn )

일치하는 각 요소의 클릭 이벤트에 함수를 바인딩합니다.

7

dblclick( )

일치하는 각 요소의 dblclick 이벤트를 트리거합니다.

8

dblclick( fn )

일치하는 각 요소의 dblclick 이벤트에 함수를 바인드합니다.

9

error( )

일치하는 각 요소의 오류 이벤트를 트리거합니다.

10

error( fn )

일치하는 각 요소의 오류 이벤트에 함수를 바인딩합니다.

11

focus( )

일치하는 각 요소의 포커스 이벤트를 트리거합니다.

12

focus( fn )

일치하는 각 요소의 포커스 이벤트에 함수를 바인딩합니다.

13

keydown( )

일치하는 각 요소의 keydown 이벤트를 트리거합니다.

14

keydown( fn )

일치하는 각 요소의 keydown 이벤트에 함수를 바인딩합니다.

15

keypress( )

일치하는 각 요소의 키 누르기 이벤트를 트리거합니다.

16

keypress( fn )

일치하는 각 요소의 키 누르기 이벤트에 함수를 바인딩합니다.

17

keyup( )

일치하는 각 요소의 키업 이벤트를 트리거합니다.

18

keyup( fn )

일치하는 각 요소의 keyup 이벤트에 함수를 바인딩합니다.

19

load( fn )

일치하는 각 요소의로드 이벤트에 함수를 바인딩합니다.

20

mousedown( fn )

일치하는 각 요소의 mousedown 이벤트에 함수를 바인딩합니다.

21

mouseenter( fn )

일치하는 각 요소의 mouseenter 이벤트에 함수를 바인딩합니다.

22

mouseleave( fn )

일치하는 각 요소의 mouseleave 이벤트에 함수를 바인딩합니다.

23

mousemove( fn )

일치하는 각 요소의 mousemove 이벤트에 함수를 바인딩합니다.

24

mouseout( fn )

일치하는 각 요소의 mouseout 이벤트에 함수를 바인딩합니다.

25

mouseover( fn )

일치하는 각 요소의 mouseover 이벤트에 함수를 바인딩합니다.

26

mouseup( fn )

일치하는 각 요소의 mouseup 이벤트에 함수를 바인딩합니다.

27

resize( fn )

일치하는 각 요소의 크기 조정 이벤트에 함수를 바인딩합니다.

28

scroll( fn )

일치하는 각 요소의 스크롤 이벤트에 함수를 바인딩합니다.

29

select( )

일치하는 각 요소의 선택 이벤트를 트리거합니다.

30

select( fn )

일치하는 각 요소의 선택 이벤트에 함수를 바인딩합니다.

31

submit( )

일치하는 각 요소의 제출 이벤트를 트리거합니다.

32

submit( fn )

일치하는 각 요소의 제출 이벤트에 함수를 바인드하십시오.

33

unload( fn )

일치하는 각 요소의 언로드 이벤트에 함수를 바인딩합니다.