基于CairngormMVC框架的Flex的设计与开发

基于CairngormMVC框架的Flex的设计与开发

ID:36622076

大小:64.50 KB

页数:15页

时间:2019-05-13

基于CairngormMVC框架的Flex的设计与开发_第1页
基于CairngormMVC框架的Flex的设计与开发_第2页
基于CairngormMVC框架的Flex的设计与开发_第3页
基于CairngormMVC框架的Flex的设计与开发_第4页
基于CairngormMVC框架的Flex的设计与开发_第5页
资源描述:

《基于CairngormMVC框架的Flex的设计与开发》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、Cairngorm框架简介Cairngorm是一种MVC框架,它可以帮助开发者很好的组织代码,分层,从而使得代码更加清晰易懂,可以使设计者,UI组件开发者,数据服务开发者并行工作,从而提高开发效率。Cairngorm由五大组件构成,分别作为存放数据的仓库(ModelLocator),存放服务的仓库(ServiceLocator),处理业务逻辑的命令(Command),自定义的用于触发命令执行的事件(Event),用于把事件映射到命令的前端控制器(FrontController)。它应用了代理模式,命令模式,观察者和单例等几种设计模式。回页首Cairngorm详解ModelLoc

2、ator:用于保存应用程序的数据,与HttpSession类似,区别主要在于数据是保存客户端,实现时将ModelLocator实现为单例,所有的应用数据都存储在唯一的一个ModelLocator对象中。CairngormEvent:这个类由Cairngorm框架提供,位于包com.adobe.cairngorm.control,所有的自定义的事件类都必须继承CairngormEvent,在自定义事件类中定义VO的引用,可以通过它来存储从View层传递过来的VO。ICommand:命令接口,位于包com.adobe.cairngorm.commands,每个命令类需要实现ICom

3、mand接口,命令类用于处理业务逻辑,通过实现其execute方法来实现业务逻辑。execute方法以事件作为参数,通过传入的事件中包含的详细信息来进行相应的处理。FrontController:前端控制器,位于包com.adobe.cairngorm.control,自定义的前端控制器必须继承FrontController,它主要用于完成CairngormEvent和ICommand之间的映射。CairngormEventDispatcher:CairngormEvent的分发器,位于包com.adobe.cairngorm.controlDelegate:服务代理,一般定义

4、一个Delegate类,持有ServiceLocator的引用,Delegate类是唯一的了解Service有关的类。回页首系统处理流程图1.使用Cairngorm后系统处理流程在基于Cairngorm的应用程序中,应用程序的数据都放在一个仓库中,这个仓库就是ModelLocator,整个应用程序只生成维护一个ModelLocator的实例,在需要数据的组件中引用这个实例。比如视图需要数据进行渲染,那么视图就维护ModelLocator实例的引用,在视图中触发事件后,事件通过前端控制器映射为一个对应的命令,然后命令通过调用服务代理,执行相应的逻辑,命令通过更新自身维护的Mode

5、lLocator的引用,因为ModelLocator只有一个,这样就相当于更新了视图。回页首安装配置开发环境开始前先让我们来搭建我们的开发环境:下载并安装JDK(本文使用版本为SunJDK6)下载并解压Eclipse(本文使用版本为EclipseGanymedeJ2EESR2版本)下载并安装FB3_WWEJ_Plugin.exe(FlexBuilder4plug-inforeclipse)下载并安装Tomcat6.x安装FB3_WWEJ_Plugin.exe过程中选中eclipse安装目录。回页首一个入门的例子前面我们讲解了Cairngorm的基本概念和一些主要的角色和类,下面

6、我用一个简单的员工管理系统的例子来进一步的理解开发过程。·下载并解压Cairngorm2.2解压出来就是一个Cairngorm.swc文件·新建FlexProject图2.新建项目Next配置服务器图3.配置服务器点击Finish.将Cairngorm.swc拷贝到项目的flex_libs目录下。在flex_src目录下建好包结构图4.建立包结构每个包中存放的内容一目了然·定义视图1在views包中新建一个MXMLComponent,基于Panel,取名为PeopleInfo.mxml,如图所示:图5.新建Panel1在里面添加一个DataGrid,还有一些文本框和按钮,如图6

7、所示:图6.视图三、这里我们希望当Panel加载完成后,从服务器读取xml文件,将员工信息给读入DataGrid中,这里,为了简单明了,仅仅定义了员工id和name属性。所以在Panel中添加属性creationComplete="LoadPersons();",然后添加标签,并添加LoadPersons()方法,原型如下所示:清单1.原型publicfunctionLoadPersons():void{}·定义ModelLocator视图中的DataGrid是需要数据

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。