फ्लेक्स - इवेंट हैंडलिंग

फ्लेक्स अनुप्रयोग के भीतर स्थिति या उपयोगकर्ता इंटरैक्शन के आधार पर डेटा को एक वस्तु से दूसरी वस्तु में पारित करने के लिए घटना की अवधारणा का उपयोग करता है।

ActionScript में एक जेनेरिक है Eventघटनाओं के साथ काम करने के लिए आवश्यक कार्यक्षमता को परिभाषित करने वाला वर्ग। जब भी कोई घटना फ्लेक्स एप्लिकेशन के भीतर होती है, तो इवेंट क्लास पदानुक्रम से तीन प्रकार की वस्तुएँ बनाई जाती हैं।

घटना में निम्नलिखित तीन प्रमुख गुण हैं

अनु क्रमांक संपत्ति विवरण
1

Type

typeइस बारे में बताता है कि किस तरह की घटना हुई। यह क्लिक, इनिशियलाइज़, माउसओवर, परिवर्तन आदि हो सकता है। वास्तविक मानों को माउसइवेंट.क्लिक जैसे स्थिरांक द्वारा दर्शाया जाएगा।

2

Target

target ईवेंट की संपत्ति उस घटक के लिए एक ऑब्जेक्ट संदर्भ है, जिसने ईवेंट उत्पन्न किया है। यदि आप क्लिक बटन पर क्लिक करते हैं, तो क्लिक करेंबटन, उस क्लिक इवेंट का लक्ष्य क्लिकबटन होगा

3

CurrentTarget

currentTargetसंपत्ति कंटेनर पदानुक्रम बदलती है। यह मुख्य रूप से घटनाओं के प्रवाह से संबंधित है।

घटना प्रवाह चरण

ईवेंट हैंडलर की तलाश में एक घटना तीन चरणों से गुजरती है।

अनु क्रमांक चरण और विवरण
1

Capture

कैप्चर चरण में, कार्यक्रम बाहरी (या शीर्ष) माता-पिता से सबसे अंतरतम तक घटना संचालकों की तलाश शुरू करेगा। कैप्चर चरण ऑब्जेक्ट के माता-पिता पर रुक जाता है जिसने घटना को ट्रिगर किया।

2

Target

लक्ष्य चरण में, इवेंट को ट्रिगर करने वाले घटक को इवेंट हैंडलर के लिए चेक किया जाता है।

3

Bubble

बबल चरण कैप्चर चरण के पीछे है, संरचना के माध्यम से वापस काम कर रहा है, लक्ष्य घटक के माता-पिता से।

निम्नलिखित आवेदन कोड पर विचार करें -

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%" minWidth = "500" minHeight = "500" >
   
   <s:Panel>
      <s:Button id = "clickMeButton" label = "Click Me!" click = "doAction( );" />
   </s:Panel>   
</s:Application>

जब उपयोगकर्ता बटन पर क्लिक करता है, तो वह पैनल या एप्लिकेशन पर भी क्लिक करता है।

ईवेंट हैंडलर असाइनमेंट की तलाश में घटना तीन चरणों से गुजरती है।

आइए हम फ्लेक्स एप्लिकेशन में ईवेंट हैंडिंग का परीक्षण करने के लिए नीचे दिए गए चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%" minWidth = "500" minHeight = "500">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         protected function reportEvent(event:MouseEvent):void {
            var target:String = event.target.id;
            var currentTarget:String = event.target.id;
            var eventPhase: String;

            if(event.target is Button) {
               var button:Button = event.target as Button;
               target = button.label + " Button";
            } else if(event.target is HGroup) {
               var hGroup:HGroup = event.target as HGroup;
               target = hGroup.id + " HGroup";
            } else if(event.target is Panel) {
               var panel:Panel = event.target as Panel;
               target = panel.id + " Panel";
            }

            if(event.currentTarget is Button) {
               var button1:Button = event.currentTarget as Button;
               currentTarget = button1.label + " Button";
            } else if(event.currentTarget is HGroup) {
               var hGroup1:HGroup = event.currentTarget as HGroup;
               currentTarget = hGroup1.id + " HGroup";
            } else if(event.currentTarget is Panel) {
               var panel1:Panel = event.currentTarget as Panel;
               currentTarget = panel1.id + " Panel";
            }

            var eventPhaseInt:uint = event.eventPhase;

            if(eventPhaseInt == EventPhase.AT_TARGET) {
               eventPhase = "Target";
            } else if(eventPhaseInt == EventPhase.BUBBLING_PHASE) {
               eventPhase = "Bubbling";
            } else if(eventPhaseInt == EventPhase.CAPTURING_PHASE) {
               eventPhase = "Capturing";
            }
            
            reports.text += " Target: " + target + "\n currentTarget: " +
               currentTarget + "\n Phase: " + eventPhase + "\n----------\n";
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "630" height = "480" id = "mainContainer"
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "10"
         horizontalAlign = "center" verticalAlign = "middle">
         <s:Label id = "lblHeader" text = "Event Handling Demonstration"
            fontSize = "40" color = "0x777777" styleName = "heading" />

         <s:Panel id = "parentPanel" title = "Main Parent"
            click = "reportEvent(event)" width = "500"
            height = "100" includeInLayout = "true" visible = "true">
            <s:layout>
               <s:VerticalLayout  gap = "10" verticalAlign = "middle"
                  horizontalAlign = "center" />
            </s:layout>
            
            <s:HGroup id = "mainHGroup" click = "reportEvent(event)">
               <s:Button label = "Click Me" click = "reportEvent(event)" />
            </s:HGroup>
         </s:Panel>

         <s:Panel id = "reportPanel" title = "Events" width = "500" height = "230">
            <mx:Text id = "reports" />
         </s:Panel>
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]