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 ) 일치하는 각 요소의 언로드 이벤트에 함수를 바인딩합니다. |