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 )

प्रत्येक मिलान तत्व के अनलोड घटना के लिए एक समारोह बांधता है।