主页 > 知识库 > FLEX 事件机制-自定义事件介绍

FLEX 事件机制-自定义事件介绍

热门标签:天津企业外呼系统代理商 外呼系统号码显示 无锡电销外呼系统代理 广州ai外呼系统业务 什么行业需要电话机器人 中山外呼系统中间件 车载电话机器人 南昌crm外呼系统如何 地图标注多家店
最近在做地图JS和FLEX的封装工作,flex封装需要用到自定义事件这方面知识,在这里就简单介绍一下FLEX自定义事件。

自定义事件必须注意几点:

(1)自定义事件通过继承Event类来实现。

(2)自定义事件不可以自己触发,只能有系统事件派发。

首先我们新建一个ActionScript 类,这个类继承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");
}
}
}

创建一个组件来监听事件,实现数据的接受。

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);//监听事件

}
public function myEventHandler(eve:Object):void{

inpu.text = eve.data;
Alert.show("事件触发,"+eve.data);
}

]]>
/fx:Script>

fx:Declarations>
!-- 将非可视元素(例如服务、值对象)放在此处 -->
/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);//派发事件 myEve.data is Object;
this.dispatchEvent(myEve);

}

]]>
/fx:Script>

fx:Declarations>
!-- 将非可视元素(例如服务、值对象)放在此处 -->
/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>

标签:攀枝花 沧州 佛山 钦州 吕梁 仙桃 泰州 海西

巨人网络通讯声明:本文标题《FLEX 事件机制-自定义事件介绍》,本文关键词  FLEX,事件,机制,自定义,介绍,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《FLEX 事件机制-自定义事件介绍》相关的同类信息!
  • 本页收集关于FLEX 事件机制-自定义事件介绍的相关信息资讯供网民参考!
  • 推荐文章