फ्लेक्स - जीवन चक्र चरण
फ्लेक्स एप्लीकेशन का जीवन चक्र
यद्यपि, आप किसी एप्लिकेशन के जीवन चक्र के चरणों को समझे बिना फ्लेक्स अनुप्रयोगों का निर्माण कर सकते हैं, यह बुनियादी तंत्र को जानना अच्छा है; क्रम जिसमें चीजें होती हैं। यह आपको रनटाइम पर अन्य फ्लेक्स एप्लिकेशन लोड करने जैसी सुविधाओं को कॉन्फ़िगर करने में मदद करेगा, और रनटाइम पर क्लास लाइब्रेरी और परिसंपत्तियों को लोड करने और उतारने की प्रक्रिया का प्रबंधन करेगा।
फ्लेक्स एप्लिकेशन जीवन चक्र की एक अच्छी समझ आपको बेहतर एप्लिकेशन बनाने और उन्हें ऑप्टिमाइज़ करने में सक्षम बनाएगी क्योंकि आपको पता होगा कि कोड को बेहतर तरीके से कहां चलाना है। उदाहरण के लिए, यदि आपको यह सुनिश्चित करने की आवश्यकता है कि कुछ कोड प्रीलोडर के दौरान चलते हैं, तो आपको यह जानना होगा कि उस घटना के लिए कोड कहां रखा जाए।
जब हम किसी ब्राउज़र में फ्लेक्स एप्लिकेशन लोड करते हैं, तो फ्लेक्स एप्लिकेशन के जीवनचक्र के दौरान निम्न घटनाएं होती हैं।
विभिन्न फ्लेक्स जीवन चक्र घटनाओं के बारे में संक्षिप्त विवरण निम्नलिखित है।
अनु क्रमांक | घटना विवरण |
---|---|
1 | preInitialize: mx.core.UIComponent.preinitialize इवेंट प्रकार: mx.events.FlexEvent.PREINITIALIZE इस घटना को घटक आरंभीकरण अनुक्रम की शुरुआत में भेजा जाता है। जब यह ईवेंट भेजा जाता है तो घटक बहुत कच्ची अवस्था में होता है। कई घटक, जैसे बटन नियंत्रण कार्यक्षमता को लागू करने के लिए आंतरिक बाल घटक बनाता है। उदाहरण के लिए, बटन नियंत्रण अपने लेबल पाठ का प्रतिनिधित्व करने के लिए एक आंतरिक UI TextField घटक बनाता है। जब फ्लेक्स प्री-इनिशियल इवेंट को भेजता है, तो एक घटक के सभी आंतरिक बच्चों सहित बच्चों को अभी तक नहीं बनाया गया है। |
2 | initialize: mx.core.UIComponent.initialize इवेंट प्रकार: mx.events.FlexEvent.INITIALIZE यह घटना पूर्व-प्रारंभिक चरण के बाद भेजी जाती है। फ्लेक्स फ्रेमवर्क इस चरण के दौरान इस घटक की आंतरिक संरचना को आरंभ करता है। जब घटक को माता-पिता में जोड़ा जाता है, तो यह घटना अपने आप आग जाती है। आपको आमतौर पर इनिशियलाइज़ () कॉल करने की आवश्यकता नहीं है। |
3 | सृष्टि निर्माण: mx.core.UIComponent.creationComplete इवेंट प्रकार: mx.events.FlexEvent.CREATION_COMPLETE इस घटना को तब भेजा जाता है जब घटक ने अपना निर्माण, संपत्ति प्रसंस्करण, माप, लेआउट और ड्राइंग समाप्त कर लिया हो। इस बिंदु पर, इसकी दृश्यमान संपत्ति के आधार पर, घटक दिखाई नहीं देता है, भले ही इसे खींचा गया हो। |
4 | applicationComplete: spark.computers.Application.applicationComplete घटना का प्रकार: mx.events.FlexEvent.APPLICATION_COMPLETE आवेदन शुरू होने के बाद डिस्पैच, लेआउटमैन द्वारा संसाधित, और प्रदर्शन सूची में संलग्न किया गया है। यह एप्लिकेशन निर्माण जीवन चक्र की अंतिम घटना है और यह दर्शाता है कि आवेदन पूरी तरह से लोड हो गया है। |
फ्लेक्स जीवन चक्र उदाहरण
आइए हम एक परीक्षण एप्लिकेशन बनाकर एक फ्लेक्स एप्लिकेशन के परीक्षण जीवन चक्र को समझने के लिए चरणों का पालन करें -
कदम | विवरण |
---|---|
1 | एक पैकेजकॉम के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं। Flexspoint.client फ्लेक्स में बताया गया है - एप्लिकेशन अध्याय बनाएं । |
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"
initialize = "reportEvent(event)"
preinitialize = "reportEvent(event)"
creationComplete = "reportEvent(event)"
applicationComplete = "reportEvent(event)">
<fx:Style source = "/com/tutorialspoint/client/Style.css" />
<fx:Script>
<![CDATA[
import mx.controls.Alert;
import mx.events.FlexEvent;
[Bindable]
private var report:String = "";
private function reportEvent(event:FlexEvent):void {
report += "\n" + (event.type + " event occured at: "
+ getTimer() + " ms" + "\n");
}
]]>
</fx:Script>
<s:BorderContainer width = "500" height = "500" id = "mainContainer"
styleName = "container">
<s:VGroup width = "100%" height = "100%" gap = "50"
horizontalAlign = "center" verticalAlign = "middle">
<s:Label textAlign = "center" width="100%" id = "lblHeader"
fontSize = "40" color = "0x777777" styleName = "heading"
text = "Life Cycle Events Demonstration" />
<s:TextArea id = "reportText" text = "{report}" editable = "false"
width = "300" height = "200">
</s:TextArea>
</s:VGroup>
</s:BorderContainer>
</s:Application>
एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]