FLEX自定义事件
有时候我们需要让两个组件之间实现联动,并且在其中传递数据,自定义事件机制可以帮助我们比较优雅的实现这种需要.
下面的例子,是打算实现一个列表和一个编辑框的联动.
编辑框代码
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" xmlns:ns1="*" creationComplete="init()">
- <mx:Script>
- <![CDATA[
- import my.DummySelectEvent;
- import mx.controls.Alert;
- private function init():void
- {
- DummySelectEvent.dispatcher.addEventListener(DummySelectEvent.SELECTED_DATA_CHANGE,dataChangeListener);
- }
- private function dataChangeListener(event:DummySelectEvent):void
- {
- var data = event.data;
- //Alert.show(event.data.name);
- detailPanel.changeMode(Detail.EDIT_SIMPLE,data);
- }
- ]]>
- </mx:Script>
- <mx:HBox x="104" y="126" width="1000">
- <ns1:List>
- </ns1:List>
- <ns1:Detail id="detailPanel" x="104" y="135" widthInit="0" widthAdvanced="600">
- </ns1:Detail>
- </mx:HBox>
- </mx:Application>
列表代码
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Panel xmlns:mx="http://www.adobe.com/2006/mxml" layout="vertical" width="100%" height="300" xmlns:my="my.*" creationComplete="initList()" xmlns:local="*">
- <mx:Script>
- <![CDATA[
- import my.DummySelectEvent;
- import mx.events.FlexEvent;
- import my.Dummy;
- import mx.collections.ArrayCollection;
- import mx.controls.Alert;
- private var dummyList:ArrayCollection;
- private var itemSelected:Boolean = false;
- private function initList():void{
- dummyList = new ArrayCollection();
- for( var i:Number = 0;i<10;i++)
- {
- var dummy:Dummy = new Dummy();
- dummy.name = "name"+i;
- dummy.email = "email"+i;
- dummy.mobile = "mobile" +i;
- dummy.address = "address"+i;
- dummy.qq = "qq"+i;
- dummy.msn = "msn"+i;
- dummyList.addItem(dummy);
- }
- dataGrid.dataProvider = dummyList;
- }
- private function itemSelect():void
- {
- var dataChangeEvent:DummySelectEvent = new DummySelectEvent(dataGrid.selectedItem,DummySelectEvent.SELECTED_DATA_CHANGE);
- DummySelectEvent.dispatcher.dispatchEvent(dataChangeEvent);
- }
- private function deleteItem():void{
- Alert.show("确定要删除?");
- }
- ]]>
- </mx:Script>
- <!--<mx:Label id="selectedItem" visible="false" data = "{dataGrid.selectedItem}" dataChange="itemSelect()"/>-->
- <mx:Spacer height="2">
- </mx:Spacer>
- <local:ListBar>
- </local:ListBar>
- <mx:DataGrid id="dataGrid"
- x="0" y="0" width="100%" height="100%"
- data="{dataGrid.selectedItem}"
- dataChange="itemSelect()" >
- <mx:columns>
- <mx:DataGridColumn headerText="name" dataField="name"/>
- <mx:DataGridColumn headerText="email" dataField="email"/>
- <mx:DataGridColumn headerText="mobile" dataField="mobile"/>
- </mx:columns>
- </mx:DataGrid>
- <mx:HBox width="100%">
- <mx:Button label="删除选中" enabled="{itemSelected}" click="deleteItem()"/>
- </mx:HBox>
- </mx:Panel>
DummyVO代码
- package my
- {
- [Bindable]
- public class Dummy
- {
- public function Dummy()
- {
- }
- public var name:String;
- public var mobile:String;
- public var email:String;
- public var qq:String;
- public var msn:String;
- public var address:String;
- }
- }
自定义事件代码
- package my
- {
- import flash.events.Event;
- import flash.events.EventDispatcher;
- public class DummySelectEvent extends Event
- {
- public var data:Object;
- public static var SELECTED_DATA_CHANGE:String = "selectedDataChange";
- public static const dispatcher:EventDispatcher=new EventDispatcher();
- public function DummySelectEvent(data:Object,type:String)
- {
- super(type,true,false);
- this.data = data;
- }
- override public function clone():Event
- {
- return new DummySelectEvent(data,type);
- }
- }
- }
主程序代码
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" xmlns:ns1="*" creationComplete="init()">
- <mx:Script>
- <![CDATA[
- import my.DummySelectEvent;
- import mx.controls.Alert;
- private function init():void
- {
- DummySelectEvent.dispatcher.addEventListener(DummySelectEvent.SELECTED_DATA_CHANGE,dataChangeListener);
- }
- private function dataChangeListener(event:DummySelectEvent):void
- {
- var data = event.data;
- //Alert.show(event.data.name);
- detailPanel.changeMode(Detail.EDIT_SIMPLE,data);
- }
- ]]>
- </mx:Script>
- <mx:HBox x="104" y="126" width="1000">
- <ns1:List>
- </ns1:List>
- <ns1:Detail id="detailPanel" x="104" y="135" widthInit="0" widthAdvanced="600">
- </ns1:Detail>
- </mx:HBox>
- </mx:Application>
FLEX自定义事件的更多相关文章
- Flex 自定义事件
一.分派自定义事件类型 任何实现flash.event.IEventDispatcher接口的对象都可以分派事件,这包括所有显示对象和一些非显示对象类.通常,对于 自定义的非显示类,可以通过扩展fla ...
- Flex事件机制学习-自定义事件实现类间通信 .
今天,学习Flex自定义事件,可以使两个类通信,定义一个Main类. public class Main extends Sprite { public function ...
- 【教程】【FLEX】#003 自定义事件、模块间通讯
本篇笔记,主要阐明 事件是如何创建 和 如何使用自定义事件达到模块之间通讯 的效果. 句子解释: 什么叫做模块之间的通讯呢?? 简单点说,就是两个模块之间可以互相传数据. A模块 可以接收到 B模块的 ...
- Flex之自定义事件
1.通过dispatchEvent委托事件模式完成自定义事件: <?xml version="1.0" encoding="utf-8"?> < ...
- flex中dispatchEvent的用法(自定义事件) .
Evevt和EventDispatcher类在as3的事件机制中是很重要的角色,dispatchEvent()是EventDispatcher类的一个事件发送方法,它可以发送出Event类或其子类的实 ...
- [置顶] flex4事件监听与自定义事件分发(三)
1.我们来说一下自定义事件子类.什么时候创建新的事件类以及怎么创建. (1)说一下,我们什么时候需要自定义事件类.举例说明,在flex中事件的基类是Event,而当我们点击某个按钮或者是单击某个组件的 ...
- Flex自定义组件开发之日周月日期选择日历控件
原文:Flex自定义组件开发之日周月日期选择日历控件 使用过DateField的我们都知道,DateField 控件是用于显示日期的文本字段,字段右侧带有日历图标.当用户在控件边框内的 ...
- ExtJS自定义事件
1.开发ExtJS组件UI的时候,基本上对于一些操作,就是与后台交互之类的多数都是用户进行点击触发一个事件,在事件的处理器handler里面调具体的业务方法,完成业务数据的处理以及业务流程的流转机制, ...
- flex 自定义组件的编写
使用flex也很久了,也改过别人写的flex自定义组件,但是就是没有系统的研究下flex组件的编写步骤,和要注意的东西,在这里我参照一本书中的例子,好好的理解下,也为了巩固下自己对flex的理解! 1 ...
随机推荐
- [数据库操作]Java中的JDBC的使用方法.
前言:想必大家在实际编码中都遇到过JDBC的操作, 这里仅做自己的一个总结, 有错误和不完整之处还请大家提出来. 1,JDBC其实一套规范(接口)数据库厂商需要实现此接口(实现类)--数据库驱动 2, ...
- iOS-SVN、Git
版本控制SVN和Git使用详解 公司的实际开发中,在天朝使用较多的还是SVN,因为SVN是集中式的,在天朝上班你们都懂的! -----------------svn--------- ...
- 更改Linux默认栈空间的大小
有时候在Linux写C++程序处理大量的数据,程序内部需要分配很大的数组来存放一些数据,但有时候分配的数组太大的话运行时会出现段错误.这种情况可能是分配的数组大小超过了Linux系统的默认栈空间的大小 ...
- curl常用操作
1.cURL介绍 cURL 是一个利用URL语法规定来传输文件和数据的工具,支持很多协议,如HTTP.FTP.TELNET等.最爽的是,PHP也支持 cURL 库.本文将介绍 cURL 的一些高级特性 ...
- Activiti 查看流程图
package com.mycom.processDefinition; import java.io.File; import java.io.IOException; import java.io ...
- 好老板VS坏老板
以下是漫画图解: 现在大家应该都能做出正确的判断了吧? 那90后的员工碰上70后的老板又会如何呢? 过去30多年来,基于资源禀赋.行政区划及产业政策等,形成了不同城市发展格局,接下来十年中国经济结构调 ...
- "无法启动应用程序,工作组信息文件丢失,或是已被其他用户已独占方式打开"解决办法
当程序用ado的jet4.0方式连接mdb数据库的时候,对于设有access数据库密码的mdb的访问居然报错“无法启动应用程序,工作组信息文件丢失,或是已被其他用户已独占方式打开”. ADOConne ...
- Mac工具
iterm2是一个替代终端和iTerm的后继项目.它支持 OS 10.5 或者更新版本.iterm2 提供更多你需要的功能和特点. Flashlight,快速且全面地显示所有「关键词」索引出的结果 参 ...
- 【原创】开源BI领袖-SpagoBI5.X最详细的中文版介绍
SpagoBI是唯一100%的开源商业智能套件由 Engineering Group的SpagoBI实验室(www.eng.it)开发和管理.它提供了强大的分析能力,从传统的报表和图表功能到自助分析. ...
- 3.C#中泛型类的进一步探讨
阅读目录 一:多重泛型 class不仅可以有T,还可以有K,实例化的时候传多个数据类型的类型,C#集合类型中的Dictionary就是多重泛型 using System; using System. ...