Flex4 事件机制2
发布时间:2020-12-15 03:42:35 所属栏目:百科 来源:网络整理
导读:?在Flex开发中,很多时候需要在父子组件之间传递数据,通过事件可以实现数据的传递,现在写一个简单的例子,在一个Flex应用中有一个TextArea,并且引入了一个自定义组件,自定义组件中有一个Button,点击这个Button,传递一个字符串在TextArea中显示。详细过
?在Flex开发中,很多时候需要在父子组件之间传递数据,通过事件可以实现数据的传递,现在写一个简单的例子,在一个Flex应用中有一个TextArea,并且引入了一个自定义组件,自定义组件中有一个Button,点击这个Button,传递一个字符串在TextArea中显示。详细过程如下: ? ? ? ?1. 创建主应用文件和自定以组件。 ? ? ? ?EventTest.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" minWidth="955" minHeight="600" xmlns:components="components.*"> <s:layout> <s:VerticalLayout/> </s:layout> <s:TextArea id="textArea" /> <components:component1 id="component" /> </s:Application> ?components/component1.mxml <?xml version="1.0" encoding="utf-8"?> <s:Group xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="library://ns.adobe.com/flex/mx"> <s:Button label="显示内容" /> </s:Group> ??2. 点击子组件的按钮会抛出一个事件,这个事件可以被主应用捕捉到并进行处理,显然这个事件需要我们自定义。
? ? ? ?events/TestEvent.as,在实际开发中,并不推荐以My起头作为类名,这里只是用于测试。 package events { import flash.events.Event; /** * 自定义事件 * */ public class TestEvent extends Event { /** * 显示信息 * @default */ public static const SHOWINFO:String = "showInfo"; /** * 存储数据 * @default */ public var data:*; /** * * @param type 事件类型 * @param bubbles 事件是否可以冒泡,true为可以,false为不可以 * @param cancelable 事件是否可以取消,true为可以,false为不可以 */ public function TestEvent(type:String,bubbles:Boolean=false,cancelable:Boolean=false) { super(type,bubbles,cancelable); } } } ?? ?Flex中声明常量使用const,并且不需要var关键字,final用于声明方法和类,详情请查看Flex API,在实际开发中,可以把自定义事件按功能类别来划分,就像Flex中包含的那些事件一样。 ? ? ? ?3. 在自定义组件中将事件抛出,在components/component1.mxml中加入如下代码。 <fx:Script> ? <![CDATA[ ? ? import events.MyEvent; ? ? // 点击button触发的函数 ? ? protected function buttonClickHandler(event:MouseEvent):void ? ? { ? ? ? var myEvent:TestEvent = new TestEvent(TestEvent.SHOWINFO); ? ? ? myEvent.data = "哈哈"; ? ? ? this.dispatchEvent(myEvent); ? ? } ? ]]> </fx:Script> <fx:Metadata> ? [Event(name="showInfo",type="events.TestEvent")] </fx:Metadata> 这里在metadata标签下声明了showInfo事件,这样,在主应用中引入的自定义组件中就会有showInfo事件属性。 ? ? ? ?4. 在主应用中捕获事件,并处理,EventTest.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" minWidth="955" minHeight="600" xmlns:components="components.*"> <fx:Script> <![CDATA[ import events.TestEvent; protected function componentShowInfoHandler(event:TestEvent):void { textArea.text = event.data; } ]]> </fx:Script> <s:layout> <s:VerticalLayout/> </s:layout> <s:TextArea id="textArea" /> <components:component1 id="component" showInfo="componentShowInfoHandler(event)" /> </s:Application> ?这里要说明一下,有两种处理方式,第一种就是这样,在子组件的metadata标签中声明了showInfo事件,如果没有声明,就找不到showInfo属性了,只能通过component.addEventListener(TestEvent.SHOWINFO,componentShowInfoHandler);这种方式来处理。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |