Flex教程

Flex 生命周期阶段

Flex 应用的生命周期

虽然您可以在不了解应用程序生命周期阶段的情况下构建 Flex 应用程序,但了解其基本机制是很好的;事物发生的顺序。它将帮助您配置运行时加载其他 Flex 应用程序等功能,并管理运行时加载和卸载类库和资产的过程。
充分了解 Flex 应用程序生命周期将使您能够构建更好的应用程序并对其进行优化,因为您将知道在何处以最佳方式运行代码。例如,如果您需要确保某些代码在预加载器期间运行,您需要知道该事件的代码放在哪里。
生命周期事件
当我们在浏览器中加载 flex 应用程序时,在 flex 应用程序的生命周期中会发生以下事件。
以下是有关不同 Flex 生命周期事件的简要详细信息。
Sr.No 事件和描述
1
preInitialize:mx.core.UIComponent.preinitialize
事件类型:mx.events.FlexEvent.PREINITIALIZE
在组件初始化开始时调度此事件序列。分派此事件时,组件处于非常原始的状态。许多组件(例如 Button 控件)创建内部子组件来实现功能。例如,Button 控件创建一个内部 UI TextField 组件来表示其标签文本。
当 Flex 调度 pre-initialize 事件时,组件的子项(包括所有内部子项)尚未已创建。
2
初始化:mx.core.UIComponent.initialize
事件类型:mx.events.FlexEvent.INITIALIZE
此事件在预初始化阶段之后调度。 Flex 框架在此阶段初始化此组件的内部结构。当组件添加到父级时,此事件会自动触发。
通常不需要调用 initialize()。
3
creationComplete:mx.core.UIComponent.creationComplete
事件类型:mx.events.FlexEvent.CREATION_COMPLETE
当组件完成构建时调度此事件,属性处理,测量,布局,绘制。
此时,根据其visible属性,组件即使绘制了也不可见。
4
applicationComplete:spark.components.Application.applicationComplete
事件类型:mx.events.FlexEvent.APPLICATION_COMPLETE
在应用程序初始化后调度,由LayoutManager,并附加到显示列表中。
这是应用程序创建生命周期的最后一个事件,表示应用程序已完全加载。

Flex 生命周期示例

让我们按照步骤通过创建测试应用程序来了解 Flex 应用程序的测试生命周期-
步骤 描述
1 在 packagecom.lidihuo.client 下创建一个名为 HelloWorld 的项目,如 Flex-创建应用程序 章节所述。
2 修改HelloWorld.mxml,如下所述。保持其余文件不变。
3 编译并运行应用程序以确保业务逻辑按照要求工作。
以下是修改后的mxml文件 src/com.lidihuo/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/lidihuo/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>
一旦您准备好完成所有更改,让我们像在Flex-创建应用程序一章中那样,以正常模式编译和运行应用程序。如果您的应用程序一切正常,它将产生以下结果:[ 在线试用 ]
Flex 应用程序生命周期
昵称: 邮箱:
Copyright © 2022 立地货 All Rights Reserved.
备案号:京ICP备14037608号-4