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>
यह कोड विभाजन तत्व को क्लिक ईवेंट पर प्रतिक्रिया देने का कारण बनेगा; जब कोई उपयोगकर्ता इस विभाजन के अंदर क्लिक करता है, तो अलर्ट दिखाया जाएगा।
यह निम्नलिखित परिणाम देगा -
बाइंड का पूरा सिंटैक्स () कमांड निम्नानुसार है -
selector.bind( eventType[, eventData], handler)
निम्नलिखित मापदंडों का वर्णन है -
eventType- जावास्क्रिप्ट घटना प्रकार वाला एक स्ट्रिंग, जैसे कि क्लिक या सबमिट करें। इवेंट प्रकारों की पूरी सूची के लिए अगले अनुभाग का संदर्भ लें।
eventData - यह वैकल्पिक पैरामीटर है डेटा का एक नक्शा है जो इवेंट हैंडलर को दिया जाएगा।
handler - हर बार घटना को चालू करने के लिए एक समारोह।
इवेंट हैंडलर्स को हटाना
आमतौर पर, एक घटना हैंडलर स्थापित होने के बाद, यह पेज के शेष जीवन के लिए प्रभावी रहता है। जब आप ईवेंट हैंडलर को निकालना चाहेंगे, तो कोई आवश्यकता हो सकती है।
jQuery प्रदान करता है unbind()एक बाहर निकलने की घटना हैंडलर को हटाने के लिए आदेश। Unbind () का सिंटैक्स इस प्रकार है -
selector.unbind(eventType, handler)
or
selector.unbind(eventType)
निम्नलिखित मापदंडों का वर्णन है -
eventType- जावास्क्रिप्ट घटना प्रकार वाला एक स्ट्रिंग, जैसे कि क्लिक या सबमिट करें। इवेंट प्रकारों की पूरी सूची के लिए अगले अनुभाग का संदर्भ लें।
handler - यदि प्रदान किया गया है, तो हटाए जाने वाले विशिष्ट श्रोता की पहचान करता है।
घटना के प्रकार
अनु क्रमांक। | ईवेंट प्रकार और विवरण |
---|---|
1 | blur तब होता है जब तत्व ध्यान केंद्रित करता है। |
2 | change जब तत्व बदलता है तब होता है। |
3 | click जब एक माउस क्लिक होता है। |
4 | dblclick तब होता है जब माउस डबल-क्लिक करता है। |
5 | error तब होता है जब लोडिंग या अनलोडिंग आदि में कोई त्रुटि होती है। |
6 | focus तब होता है जब तत्व ध्यान केंद्रित करता है। |
7 | keydown तब होता है जब कुंजी दबाया जाता है। |
8 | keypress तब होता है जब कुंजी को दबाया और जारी किया जाता है। |
9 | keyup कुंजी जारी होने पर होता है। |
10 | load दस्तावेज़ लोड होने पर होता है। |
1 1 | mousedown तब होता है जब माउस बटन दबाया जाता है। |
12 | mouseenter तब होता है जब माउस एक तत्व क्षेत्र में प्रवेश करता है। |
13 | mouseleave तब होता है जब माउस एक तत्व क्षेत्र को छोड़ देता है। |
14 | mousemove तब होता है जब माउस पॉइंटर चलता है। |
15 | mouseout तब होता है जब माउस पॉइंटर एक तत्व से बाहर निकलता है। |
16 | mouseover तब होता है जब माउस पॉइंटर एक तत्व पर चलता है। |
17 | mouseup माउस बटन जारी होने पर होता है। |
18 | resize विंडो के आकार बदलने पर होता है। |
19 | scroll तब होता है जब विंडो स्क्रॉल की जाती है। |
20 | select तब होता है जब कोई पाठ चुना जाता है। |
21 | submit फॉर्म जमा होने पर होता है। |
22 | unload तब होता है जब दस्तावेज़ अनलोड किए जाते हैं। |
घटना वस्तु
कॉलबैक फ़ंक्शन एकल पैरामीटर लेता है; जब हैंडलर को जावास्क्रिप्ट ईवेंट कहा जाता है, तो ऑब्जेक्ट को इसके माध्यम से पारित किया जाएगा।
ईवेंट ऑब्जेक्ट अक्सर अनावश्यक होता है और पैरामीटर को छोड़ दिया जाता है, क्योंकि पर्याप्त संदर्भ आमतौर पर उपलब्ध होता है जब हैंडलर को यह जानने के लिए बाध्य किया जाता है कि हैंडलर ट्रिगर होने पर क्या किया जाना चाहिए, हालांकि कुछ विशेषताएं हैं जिन्हें आपको एक्सेस करने की आवश्यकता होगी।
इवेंट अटेंड करता है
अनु क्रमांक। | संपत्ति विवरण |
---|---|
1 | altKey यह निर्धारित करने के लिए कि यदि घटना चालू होने पर Alt कुंजी दबाया गया था, यदि नहीं तो गलत है। Alt कुंजी को अधिकांश मैक कीबोर्ड पर विकल्प लेबल किया जाता है। |
2 | ctrlKey सत्य को सेट करें यदि घटना शुरू होने पर Ctrl कुंजी दबाया गया था, यदि नहीं तो गलत। |
3 | data मान, यदि कोई हो, हैंडलर स्थापित होने पर बाइंड () कमांड के दूसरे पैरामीटर के रूप में पारित किया गया। |
4 | keyCode कीप और कीडाउन इवेंट के लिए, यह वह कुंजी देता है जिसे दबाया गया था। |
5 | metaKey सत्य को सेट करें यदि घटना के ट्रिगर होने पर मेटा कुंजी दबाया गया था, यदि नहीं तो गलत। मेटा कुंजी पीसी पर Ctrl कुंजी और Mac पर कमांड कुंजी है। |
6 | pageX माउस आयोजनों के लिए, पृष्ठ उत्पत्ति से संबंधित घटना के क्षैतिज समन्वय को निर्दिष्ट करता है। |
7 | pageY माउस आयोजनों के लिए, पृष्ठ उत्पत्ति से संबंधित घटना के ऊर्ध्वाधर समन्वय को निर्दिष्ट करता है। |
8 | relatedTarget कुछ माउस ईवेंट के लिए, उस तत्व की पहचान करता है जिसे इवेंट के ट्रिगर होने पर कर्सर ने छोड़ा या दर्ज किया। |
9 | screenX माउस घटनाओं के लिए, स्क्रीन उत्पत्ति से संबंधित घटना के क्षैतिज समन्वय को निर्दिष्ट करता है। |
10 | screenY माउस घटनाओं के लिए, स्क्रीन उत्पत्ति से संबंधित घटना के ऊर्ध्वाधर समन्वय को निर्दिष्ट करता है। |
1 1 | shiftKey यदि इवेंट ट्रिगर किया गया था तो Shift कुंजी दबाया गया था तो सही पर सेट करें, यदि नहीं तो गलत। |
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>
यह निम्नलिखित परिणाम देगा -
द इवेंट मेथड्स
उन तरीकों की एक सूची है जिन्हें इवेंट ऑब्जेक्ट पर कहा जा सकता है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | चूक को रोकें() डिफ़ॉल्ट क्रिया को निष्पादित करने से ब्राउज़र को रोकता है। |
2 | isDefaultPrevented () रिटर्न करता है कि क्या event.preventDefault () को कभी भी इस ईवेंट ऑब्जेक्ट पर बुलाया गया था। |
3 | stopPropagation () किसी भी पैरेंट हैंडलर्स को इवेंट के बारे में सूचित करने से रोकने के लिए, पैरेंट एलिमेंट्स को किसी ईवेंट के बबलिंग को रोक देता है। |
4 | isPropagationStopped () रिटर्न करता है कि क्या event.stopPropagation () को कभी भी इस ईवेंट ऑब्जेक्ट पर कॉल किया गया था। |
5 | stopImmediatePropagation () शेष संचालकों को निष्पादित होने से रोकता है। |
6 | isImmediatePropagationStopped () यह बताता है कि क्या event.stopImmediatePropagation () को कभी भी इस ईवेंट ऑब्जेक्ट पर कॉल किया गया था। |
घटना हेरफेर तरीके
निम्नांकित महत्वपूर्ण घटनाओं से संबंधित सारणी नीचे दी गई है -
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | बाइंड (प्रकार, [डेटा], fn) प्रत्येक मिलान तत्व के लिए एक या एक से अधिक घटनाओं (जैसे क्लिक) के लिए एक हैंडलर बांधता है। कस्टम घटनाओं को भी बांध सकता है। |
2 | बंद (ईवेंट्स, चयनकर्ता] [, हैंडलर (ईवेंटऑब्जेक्ट)]) यह लाइव के विपरीत करता है, यह एक बाध्य लाइव इवेंट को हटा देता है। |
3 | होवर (ओवर, आउट) उदाहरण के लिए, और एक वस्तु पर माउस को हिलाने के लिए मँडराता है। |
4 | पर (घटनाओं [, चयनकर्ता] [, डेटा], हैंडलर) एक हैंडलर को किसी भी घटना के लिए (जैसे क्लिक) सभी वर्तमान और भविष्य के मिलान तत्व के लिए बांधता है। कस्टम घटनाओं को भी बांध सकता है। |
5 | एक (प्रकार, [डेटा], fn) एक या अधिक घटनाओं के लिए एक हैंडलर को प्रत्येक मिलान किए गए तत्व के लिए एक बार निष्पादित किया जाता है। |
6 | तैयार (fn) जब भी DOM को ट्रेस और हेरफेर करने के लिए तैयार किया जाता है, तो एक फंक्शन निष्पादित किया जाता है। |
7 | ट्रिगर (घटना, [डेटा]) प्रत्येक मिलान किए गए तत्व पर एक घटना ट्रिगर। |
8 | ट्रिगरहैंडलर (घटना, [डेटा]) एक तत्व पर सभी बाध्य घटना संचालकों को ट्रिगर करता है। |
9 | unbind ([प्रकार], [fn]) यह बाइंड के विपरीत करता है, यह मिलान किए गए तत्वों में से प्रत्येक से बाध्य घटनाओं को हटा देता है। |
इवेंट हेल्पर के तरीके
jQuery इवेंट हेल्पर फ़ंक्शंस का एक सेट भी प्रदान करता है जिसका उपयोग या तो किसी इवेंट को ट्रिगर करने के लिए किया जा सकता है जो ऊपर बताए गए किसी भी प्रकार के इवेंट को बाइंड करने के लिए किया जाता है।
ट्रिगर के तरीके
निम्नलिखित एक उदाहरण है जो सभी पैराग्राफ पर धब्बा घटना को ट्रिगर करेगा -
$("p").blur();
बांधने के तरीके
निम्नलिखित एक उदाहरण है जो एक बांध देगा click सभी <div> पर घटना
$("div").click( function () {
// do something here
});
अनु क्रमांक। | विधि और विवरण |
---|---|
1 | blur( ) प्रत्येक मिलान तत्व के धब्बा घटना को ट्रिगर करता है। |
2 | blur( fn ) प्रत्येक मिलान तत्व के धब्बा घटना के लिए एक समारोह बाँध। |
3 | change( ) प्रत्येक मिलान तत्व के परिवर्तन की घटना को ट्रिगर करता है। |
4 | change( fn ) प्रत्येक मिलान तत्व के परिवर्तन घटना के लिए एक समारोह बांधता है। |
5 | click( ) प्रत्येक मिलान तत्व के क्लिक इवेंट को ट्रिगर करता है। |
6 | click( fn ) प्रत्येक मिलान तत्व के क्लिक इवेंट के लिए एक फ़ंक्शन को बांधता है। |
7 | dblclick( ) प्रत्येक मिलान तत्व की dblclick घटना को ट्रिगर करता है। |
8 | dblclick( fn ) प्रत्येक मिलान तत्व के dblclick घटना के लिए एक समारोह बांधता है। |
9 | error( ) प्रत्येक मिलान किए गए तत्व की त्रुटि घटना को ट्रिगर करता है। |
10 | error( fn ) प्रत्येक मिलान तत्व की त्रुटि घटना के लिए एक समारोह बांधता है। |
1 1 | focus( ) प्रत्येक मिलान तत्व के फोकस इवेंट को ट्रिगर करता है। |
12 | focus( fn ) प्रत्येक मिलान तत्व के फोकस इवेंट के लिए एक फ़ंक्शन को बांधता है। |
13 | keydown( ) प्रत्येक मिलान किए गए तत्व की कुंजीकरण घटना को ट्रिगर करता है। |
14 | keydown( fn ) प्रत्येक मिलान किए गए तत्व की कीडाउन फ़ंक्शन के लिए एक फ़ंक्शन को बांधें। |
15 | keypress( ) प्रत्येक मिलान किए गए तत्व की कुंजी घटना ट्रिगर करता है। |
16 | keypress( fn ) प्रत्येक मिलान किए गए तत्व के कीपर घटना के लिए एक फ़ंक्शन को बांधता है। |
17 | keyup( ) प्रत्येक मिलान तत्व के कीप इवेंट को ट्रिगर करता है। |
18 | keyup( fn ) प्रत्येक मिलान तत्व के कीप इवेंट के लिए एक फ़ंक्शन को बांधें। |
19 | load( fn ) प्रत्येक मिलान तत्व के भार घटना के लिए एक समारोह बांधता है। |
20 | mousedown( fn ) प्रत्येक मिलान तत्व के मूसडाउन घटना के लिए एक समारोह बांधता है। |
21 | mouseenter( fn ) प्रत्येक मिलान तत्व के माउसइंटर घटना के लिए एक समारोह में बाँध। |
22 | mouseleave( fn ) प्रत्येक मिलान तत्व के mouseleave घटना के लिए एक समारोह में बाँध। |
23 | mousemove( fn ) प्रत्येक मिलान तत्व के मूसमव इवेंट में एक फ़ंक्शन को बांधें। |
24 | mouseout( fn ) प्रत्येक मिलान किए गए तत्व के माउसआउट समारोह में एक फ़ंक्शन को बांधें। |
25 | mouseover( fn ) प्रत्येक मिलान तत्व के माउसओवर इवेंट के लिए एक फ़ंक्शन को बाइंड करें। |
26 | mouseup( fn ) प्रत्येक मिलान तत्व के माउसअप ईवेंट के लिए एक फ़ंक्शन को बाइंड करें। |
27 | resize( fn ) प्रत्येक मिलान किए गए तत्व के आकार को बदलने के लिए एक फ़ंक्शन को बांधें। |
28 | scroll( fn ) प्रत्येक मिलान तत्व के स्क्रॉल ईवेंट के लिए एक फ़ंक्शन को बाइंड करें। |
29 | select( ) प्रत्येक मिलान किए गए तत्व की चुनिंदा घटना को ट्रिगर करें। |
30 | select( fn ) प्रत्येक मिलान किए गए तत्व की चयन घटना के लिए एक फ़ंक्शन को बांधें। |
31 | submit( ) प्रत्येक मिलान किए गए तत्व की सबमिट घटना को ट्रिगर करें। |
32 | submit( fn ) प्रत्येक मिलान किए गए तत्व की घटना को सबमिट करने के लिए एक फ़ंक्शन को बांधें। |
33 | unload( fn ) प्रत्येक मिलान तत्व के अनलोड घटना के लिए एक समारोह बांधता है। |