FLEX 事件機(jī)制-自定義事件介紹
更新時(shí)間:2013年09月08日 15:54:58 作者:
flex封裝需要用到自定義事件這方面知識(shí),在這里就簡(jiǎn)單介紹一下FLEX自定義事件,感興趣的朋友可以參考下
最近在做地圖JS和FLEX的封裝工作,flex封裝需要用到自定義事件這方面知識(shí),在這里就簡(jiǎn)單介紹一下FLEX自定義事件。
自定義事件必須注意幾點(diǎn):
(1)自定義事件通過繼承Event類來實(shí)現(xiàn)。
(2)自定義事件不可以自己觸發(fā),只能有系統(tǒng)事件派發(fā)。
首先我們新建一個(gè)ActionScript 類,這個(gè)類繼承flash.events.Event。
package
{
import flash.events.Event;
public class MyEvent extends Event
{
public static const myEvent:String="myEvent";
public var data:*;
public function MyEvent(type:String,bubbles:Boolean=false,cancellabel:Boolean=false,data:* = null)
{
super(type,false,false);
this.data = data;
}
override public function clone():Event{
return new MyEvent(myEvent,false,false,data);
}
override public function toString():String{
return formatToString("MyEvent");
}
}
}
創(chuàng)建一個(gè)組件來監(jiān)聽事件,實(shí)現(xiàn)數(shù)據(jù)的接受。
component.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" width="100%" height="100%" initialize="init()">
<s:layout>
<s:BasicLayout/>
</s:layout>
<fx:Script>
<![CDATA[
import mx.controls.Alert;
import mx.events.FlexEvent;
public var ff:FlexMyEvent;
public function init():void{
ff = this.parentDocument as FlexMyEvent;
ff.addEventListener(MyEvent.myEvent,myEventHandler);//監(jiān)聽事件
}
public function myEventHandler(eve:Object):void{
inpu.text = eve.data;
Alert.show("事件觸發(fā),"+eve.data);
}
]]>
</fx:Script>
<fx:Declarations>
<!-- 將非可視元素(例如服務(wù)、值對(duì)象)放在此處 -->
</fx:Declarations>
<s:Panel width="100%" height="100%" backgroundColor="#E7D4DD">
<s:TextInput id="inpu">
</s:TextInput>
</s:Panel>
</s:Group>
主程序
FlexMyEvent.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"
xmlns:comp = "*"
width="100%" height="100%">
<fx:Script>
<![CDATA[
import flash.external.ExternalInterface;
import flash.system.Security;
import mx.controls.Alert;
import mx.events.FlexEvent;
public var callBackInfo:String = "";
public function doSend():void{
callBackInfo = input.text;
var myEve:MyEvent = new MyEvent(MyEvent.myEvent,false,false,callBackInfo);//派發(fā)事件 myEve.data is Object;
this.dispatchEvent(myEve);
}
]]>
</fx:Script>
<fx:Declarations>
<!-- 將非可視元素(例如服務(wù)、值對(duì)象)放在此處 -->
</fx:Declarations>
<mx:HBox width="100%" height="100%" horizontalAlign="center" verticalAlign="middle">
<s:Panel width="100%" height="100%">
<mx:HBox paddingLeft="5" width="100%" height="100%">
<s:TextInput id="input" text="Send Hello">
</s:TextInput>
<s:Button label="Send" click="doSend()">
</s:Button>
</mx:HBox>
</s:Panel>
<comp:Component>
</comp:Component>
</mx:HBox>
</s:Application>
自定義事件必須注意幾點(diǎn):
(1)自定義事件通過繼承Event類來實(shí)現(xiàn)。
(2)自定義事件不可以自己觸發(fā),只能有系統(tǒng)事件派發(fā)。
首先我們新建一個(gè)ActionScript 類,這個(gè)類繼承flash.events.Event。
復(fù)制代碼 代碼如下:
package
{
import flash.events.Event;
public class MyEvent extends Event
{
public static const myEvent:String="myEvent";
public var data:*;
public function MyEvent(type:String,bubbles:Boolean=false,cancellabel:Boolean=false,data:* = null)
{
super(type,false,false);
this.data = data;
}
override public function clone():Event{
return new MyEvent(myEvent,false,false,data);
}
override public function toString():String{
return formatToString("MyEvent");
}
}
}
創(chuàng)建一個(gè)組件來監(jiān)聽事件,實(shí)現(xiàn)數(shù)據(jù)的接受。
component.mxml
復(fù)制代碼 代碼如下:
<?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" width="100%" height="100%" initialize="init()">
<s:layout>
<s:BasicLayout/>
</s:layout>
<fx:Script>
<![CDATA[
import mx.controls.Alert;
import mx.events.FlexEvent;
public var ff:FlexMyEvent;
public function init():void{
ff = this.parentDocument as FlexMyEvent;
ff.addEventListener(MyEvent.myEvent,myEventHandler);//監(jiān)聽事件
}
public function myEventHandler(eve:Object):void{
inpu.text = eve.data;
Alert.show("事件觸發(fā),"+eve.data);
}
]]>
</fx:Script>
<fx:Declarations>
<!-- 將非可視元素(例如服務(wù)、值對(duì)象)放在此處 -->
</fx:Declarations>
<s:Panel width="100%" height="100%" backgroundColor="#E7D4DD">
<s:TextInput id="inpu">
</s:TextInput>
</s:Panel>
</s:Group>
主程序
FlexMyEvent.mxml
復(fù)制代碼 代碼如下:
<?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"
xmlns:comp = "*"
width="100%" height="100%">
<fx:Script>
<![CDATA[
import flash.external.ExternalInterface;
import flash.system.Security;
import mx.controls.Alert;
import mx.events.FlexEvent;
public var callBackInfo:String = "";
public function doSend():void{
callBackInfo = input.text;
var myEve:MyEvent = new MyEvent(MyEvent.myEvent,false,false,callBackInfo);//派發(fā)事件 myEve.data is Object;
this.dispatchEvent(myEve);
}
]]>
</fx:Script>
<fx:Declarations>
<!-- 將非可視元素(例如服務(wù)、值對(duì)象)放在此處 -->
</fx:Declarations>
<mx:HBox width="100%" height="100%" horizontalAlign="center" verticalAlign="middle">
<s:Panel width="100%" height="100%">
<mx:HBox paddingLeft="5" width="100%" height="100%">
<s:TextInput id="input" text="Send Hello">
</s:TextInput>
<s:Button label="Send" click="doSend()">
</s:Button>
</mx:HBox>
</s:Panel>
<comp:Component>
</comp:Component>
</mx:HBox>
</s:Application>
相關(guān)文章
Flex DataGrid自動(dòng)編號(hào)示例
這篇文章主要介紹了Flex DataGrid如何自動(dòng)編號(hào),感興趣的朋友可以參考下2014-05-05
flex利用webservice上傳照片實(shí)現(xiàn)代碼
這篇文章主要介紹了flex利用webservice上傳照片實(shí)現(xiàn)代碼,需要的朋友可以參考下2014-05-05
Flex讀取txt文件中的內(nèi)容報(bào)錯(cuò)原因分析及解決
這篇文章主要介紹了Flex讀取txt文件中的內(nèi)容報(bào)錯(cuò)原因分析及解決,需要的朋友可以參考下2014-05-05
Flex 基于數(shù)據(jù)源的Menu Tree實(shí)現(xiàn)代碼
由外部參數(shù)flashvars指定數(shù)據(jù)源的文件位置或render鏈接,在源數(shù)據(jù)上加href和target屬性來控制打開窗口,可自定義父節(jié)點(diǎn)和子節(jié)點(diǎn)圖標(biāo),不設(shè)置采用系統(tǒng)默認(rèn),感興趣的你可以了解下啊,或許對(duì)你有所幫助2013-01-01
Flex實(shí)現(xiàn)的上傳攝像頭拍照并將UI保存為圖片
這篇文章主要介紹了Flex如何實(shí)現(xiàn)上傳攝像頭拍照并將UI保存為圖片,需要的朋友可以參考下2014-05-05
獲取到AdvancedDataGrid選中行的全部數(shù)據(jù)
通過AdvancedDataGrid的id來獲取selectedItem和selectedItems屬性,下面有個(gè)不不錯(cuò)的示例大家可以參考下2014-02-02

