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,并附加到显示列表中。
这是应用程序创建生命周期的最后一个事件,表示应用程序已完全加载。
|
步骤 | 描述 |
1 | 在 packagecom.lidihuo.client 下创建一个名为 HelloWorld 的项目,如 Flex-创建应用程序 章节所述。 |
2 | 修改HelloWorld.mxml,如下所述。保持其余文件不变。 |
3 | 编译并运行应用程序以确保业务逻辑按照要求工作。 |
<?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>