版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、教你7步实现flex自定义Event及参数传递Flex应用开发过程中如需要灵活的在不同组件(如A与B,父与子)之间响应事件,传递参数等功能时就会使用自定义事件(Event)机制,下面通过一个事例分七步,通过自定义Event和EventDispatcher两种机制实现事件交互和参数传递; 事例描述:有一个父亲“parentApp.mxml”有两个儿子“comBrotherA.mxml”和"comBrotherB.mxml",新年 降至,两个儿子为表孝心分别给他们老爸存入(事件)一笔过节费(事件
2、参数),并通知老爸我存钱进去了,老爸在收到两个儿子的钱后汇总后同时告诉(事件)两 个儿子钱我已收到总数(事件参数)是多少. 1、第一步:引入自定义注册事件参数传递扩展类(来自网络) view plaincopy to clipboardprint?1. package myeventhelper 2. 3. /自定义注册事件参数传递扩展类 4. publ
3、ic class EventArgExtend 5. 6. public function EventArgExtend() 7. 8.
4、60; 9. public static function create(f:Function,.arg):Function /动态参数创建 10. 11.
5、;var F:Boolean = false; 12. var _f:Function = function(e:*,._arg) 13. 14.
6、 _arg = arg; 15. if(!F) 16. &
7、#160; 17. F = true; 18.
8、0; _arg.unshift(e); 19. 20. f.apply(null,_arg); 21.
9、; 22. return _f; 23. 24. pu
10、blic static function toString():String 25. 推荐精选26. return "Class JEventDelegate" 27.
11、160; 28. 29. 2、第二步:自定义事件触发类:view plaincopy to clipboardprint?1. package myeventhelper 2. 3. import flash.events.EventDispatcher; 4.
12、0; 5. import mx.core.UIComponent; 6. /自定义事件触发类 7. public class MyEventDispatcher extends EventDispatcher 8. 9.
13、 private static var _instance:MyEventDispatcher; 10. public static const EXEC_PARENT_METHOD:String="ExecParentMethod" /执行Parent方法 11.
14、0; public static function getInstance():MyEventDispatcher 12. 13. if(_instance=null) 14. &
15、#160; _instance=new MyEventDispatcher(); 15. 16. return _instanc
16、e; 17. 18. public var Source:UIComponent; /事件源对象 19. public var Parsms:Object; /主要用于参数传递
17、0; 20. 21. 推荐精选 3、第三步:用户自定义事件类 view plaincopy to clipboardprint?1. package myeventhelper 2. 3. import mx.e
18、vents.FlexEvent; 4. /用户自定义事件类 5. public class MyExtendEvent extends FlexEvent 6. 7. &
19、#160; public static const EXEC_BROTHER_METHOD:String="ExecBrotherMethod"/执行兄弟方法 8. 9.
20、; public var param:Object; 10. public function MyExtendEvent(o:Object,type:String, bubbles:Boolean=false, cancelable:Boolean=false) 11.
21、; 12. super(type, bubbles, cancelable); 13.
22、160; this.param = o;/也可通过这样的方式传递参数 14. 15. 16. 推荐精选 4、第四步:
23、完成儿子A“comBrotherA.mxml”: view plaincopy to clipboardprint?1. <?xml version="1.0" encoding="utf-8"?> 2. <mx:Panel xmlns:mx="3. <mx:Script> 4.
24、0; <!-CDATA 5. import myeventhelper.MyExtendEvent; 6. import myeventhelper.MyEventDispatcher
25、; 7. import myeventhelper.EventArgExtend; 8. private var execParent:MyEventDispatcher; /触发父亲节点事件 9.
26、60; function init():void 10. 11. execPa
27、rent = MyEventDispatcher.getInstance(); 12. 13. public function onGetParentTotal(e:MyExtendEvent,.agrs):void
28、; 14. 15. /下面两种方法都可以用来传递参数 16. &
29、#160; /this.labTotal.text = String(agrs0.totalValue); 17. this.labTotal.text = e.param.toString(); 18.
30、 19. public function onParentEvent(event:Event):void 20. 21.
31、60; execParent.Parsms = txtValue.text; 22. execParent.Source = this; 23.
32、 execParent.dispatchEvent(new Event(MyEventDispatcher.EXEC_PARENT_METHOD); 24. 推荐精选25.
33、 26. -> 27. </mx:Script> 28. <mx:Canvas height="90" width="197">
34、160;29. <mx:TextInput width="92" y="10" x="85" id="txtValue"/> 30. <mx:Label x="13" y=
35、"12" text="存入:"/> 31. <mx:Label x="87" y="56" width="90" id="labTotal"/> 32. <mx:Labe
36、l x="5" y="56" text="ParentTotal:"/> 33. </mx:Canvas> 34. <mx:ControlBar> 35.
37、60; <mx:Button label="调用父方法" id="btnExecParent" click="onParentEvent(event)"/> 36. </mx:ControlBar> 37. </mx:Pa
38、nel> 5、第五步:完成儿子B“comBrotherB.mxml”: view plaincopy to clipboardprint?1. <?xml version="1.0" encoding="utf-8"?> 2. <mx:Panel xmlns:mx="3. <
39、mx:Script> 4. <!-CDATA 5. import myeventhelper.MyExtendEvent; 6.
40、;import myeventhelper.MyEventDispatcher; 7. import myeventhelper.EventArgExtend; 8. 9. &
41、#160; private var execParent:MyEventDispatcher; /触发父亲节点事件 10. function init():void 推荐精选11.
42、 12. execParent = MyEventDispatcher.getInstance(); 13. 14.
43、; public function onGetParentTotal(e:Event,.agrs):void /响应父亲类的触发的事件 15. 16. &
44、#160; this.labTotal.text = String(agrs0.totalValue); 17. 18. 19.
45、; public function onParentEvent(event:Event):void /通过自定义事件触发类传递参数 20. 21.
46、60; execParent.Parsms = txtValue.text; 22. execParent.Source = this; 23.
47、 execParent.dispatchEvent(new Event(MyEventDispatcher.EXEC_PARENT_METHOD); 24. 25. -> 26. &
48、#160;</mx:Script> 27. <mx:Canvas height="90" width="197"> 28. <mx:TextInput width="92" y="10" x="
49、85" id="txtValue"/> 29. <mx:Label x="13" y="12" text="存入:"/> 30. <mx:Label x="
50、;87" y="56" width="90" id="labTotal"/> 31. <mx:Label x="5" y="56" text="ParentTotal:"/> 32.
51、0; </mx:Canvas> 33. <mx:ControlBar> 34. <mx:Button label="调用父方法" id="btnExecParent" click="o
52、nParentEvent(event)"/> 35. </mx:ControlBar> 36. </mx:Panel> 推荐精选 6、第六步:完成父亲类"parentApp.mxml": view plaincopy to clipboardprint?1.
53、 <?xml version="1.0" encoding="utf-8"?> 2. <mx:Application xmlns:mx="3. <mx:Script> 4. <!-CDATA 5.
54、160; import myeventhelper.MyExtendEvent; 6. import myeventhelper.MyEventDispatcher; 7.
55、160; import myeventhelper.EventArgExtend; 8. private var parentDP:MyEventDispatcher; 9. public var
56、;totalValue:Number = 0; 10. function init():void 11. 12.
57、160; parentDP = MyEventDispatcher.getInstance(); 13. nodeEvent = new MyExtendEvent(totalValue,MyExtendEvent.EXEC_BROTHER_METHOD
58、); 14. 15. if(!parentDP.hasEventListener(MyEventDispatcher.EXEC_PARENT_METHOD) 1
59、6. parentDP.addEventListener(MyEventDispatcher.EXEC_PARENT_METHOD,getSonValue);/注册通过自定义事件触发类传递参数 17.
60、160; 18. /注册事件时传递参数 19. addEventListener(MyE
61、xtendEvent.EXEC_BROTHER_METHOD,EventArgExtend.create(comA.onGetParentTotal,this); 推荐精选20. addEventListener(MyExtendEvent.EXEC_BROTHER_METHOD,EventArgExtend.create(comB.onGetParentTotal,this);
62、160; 21. 22. function getSonValue(e:Event):void 23.
63、; 24. if(parentDP.Source = comA) 25. 26.
64、; txtA.text = String(parentDP.Parsms); 27. 28.
65、; else 29. 30.
66、; txtB.text = String(parentDP.Parsms); 31. 32. 33. &
67、#160; 34. /将结果返回儿子节点 35. private var nodeEvent:MyExtendEvent; 36.
68、; function onSumToNode(e:Event):void/触发事件将结果返回儿子节点 37. 38.
69、0; totalValue = Number(txtA.text) + Number(txtB.text); 39. txtTotal.text = String(totalValue); 40.
70、 nodeEvent.param = totalValue; 41. dispatchEvent(nodeEvent); 42.
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年中职工业机器人技术(工业机器人操作)试题及答案
- 2025年大学第四学年(欧洲文学选读)文学思潮综合测试试题及答案
- 2025年高职(中药学)中药鉴定阶段测试题及答案
- 2025年中职第二学年(物流信息技术)物流信息采集实操测试卷
- 2025年中职机电一体化技术(液压传动)试题及答案
- 2025年大学环境设计(环境艺术创作)试题及答案
- 2025年大学能源运营管理应用(应用技术)试题及答案
- 2025年高职化工单元操作(化工设备操作)试题及答案
- 2026年河北劳动关系职业学院单招职业技能考试参考题库带答案解析
- 2026年河北化工医药职业技术学院单招综合素质笔试参考题库带答案解析
- 2025至2030中国细胞存储行业调研及市场前景预测评估报告
- 《中华人民共和国危险化学品安全法》解读
- 水暖施工员考试及答案
- 2025年省级行业企业职业技能竞赛(老人能力评估师)历年参考题库含答案
- 培养员工的协议书
- 1.1《子路、曾皙、冉有、公西华侍坐》教学课件2025-2026学年统编版高中语文必修下册
- 2025天津中煤进出口有限公司面向中国中煤内部及社会招聘第五批电力人才52人(公共基础知识)测试题附答案解析
- 2025至2030氢过氧化叔丁基(TBHP)行业运营态势与投资前景调查研究报告
- 2026年哈尔滨职业技术学院单招职业适应性考试必刷测试卷附答案
- 通信行业项目经理服务水平绩效考核表
- 副高医院药学考试试题题库及答案
评论
0/150
提交评论