Flex事件分发

    本文和大家重点讨论一下Flex事件分发的概念,在分发事件时,将会分发一个事件对象出去。不管是那个事件类,都是继承自flash.events.Event对象的,他包含一些比较重要的属性,type和bubbles。

    Flex事件分发

    最终继承自EventDispatcher的对象都会含有dispatchEvent这个方法,他有一个参数,事件对象。之前说到的事件注册通道,他只是一个通道,实际上事件是由这个方法来分发出去的,通道只是一个管道而已。

    他的作用就是分发一个事件对象,他的分发是没有目的的,一种广播形式的,Flex的事件监听线程会接收到各种各样的事件(我们称之为捕获事件,这在后面会介绍到),那么哪种才是你要的事件,标识就通过事件的type属性来区分。

    自定义Flex事件分发

    这部分就不长篇大论了,因为各位应该已经掌握了事件的原理,因此贴出演示源码,并进行些简单的解释。

    1.自定义Flex事件components/MyEventTest.as

 
  1. packagecomponents  
  2. {  
  3. importmx.events.FlexEvent;  
  4. publicclassMyEventTestextendsFlexEvent  
  5. {  
  6. publicstaticconstONCHANGE:String="onChange";  
  7. publicvareventInfo:String;//自定义的事件信息  
  8. publicfunctionMyEventTest(s:String){  
  9. super(s);//如果在构造时不设bubbles,默认是false,也就是不能传递的。  
  10. eventInfo="这个事件是:"+s;  
  11. }  
  12. }  
  13. }  
  14.  

2.自定义组件components/ComponentForEvent.as

 
  1. packagecomponents  
  2. {  
  3. importflash.events.EventDispatcher;  
  4. //这个就是声明事件注册通道的方法了。name是事件对应的名称,也就是之前提到的type。Type是该事件的类  
  5. [Event(name="onChange",type="components.MyEventTest")]  
  6. publicclassComponentForEventextendsEventDispatcher  
  7. {  
  8. privatevarname:String;  
  9. publicfunctionchangeName(newName:String){  
  10. this.name=newName;  
  11. dispatchEvent(newMyEventTest(MyEventTest.ONCHANGE));  
  12. }  
  13. }  
  14. }  
  15.  

3.自定义Flex事件分发中App.mxml代码
 

 
  1. <?xmlversionxmlversion="1.0"encoding="utf-8"?> 
  2. <mx:Applicationxmlns:mxmx:Applicationxmlns:mx="http://www.adobe.com/2006/mxml" 
  3. layout="absolute"xmlns:comp  
  4. > 
  5. <mx:Script> 
  6. <![CDATA[  
  7. importmx.controls.Alert;  
  8. privatefunctionchangeName(){  
  9. cfe.changeName("新名称");  
  10. }  
  11. ]]> 
  12. </mx:Script> 
  13. <mx:Buttonidmx:Buttonid="testBtn"click="changeName()"label="测试"/> 
  14. <components:ComponentForEvent 
  15. id="cfe"/> 
  16. </mx:Application> 

你可能感兴趣的:(Flex,Flash,Adobe)