加入收藏 |
设为首页 |
会员中心 | 我要投稿
|
李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
Flex4使用Cairngorm2框架
发布时间:2020-12-15 01:31:34 所属栏目:百科 来源:网络整理
导读:Flex4使用Cairngorm2框架 作者:准提道人 ???发表于: 2011-03-16??3:06 ???分类: ? FLex 虽然说Cairngorm框架已经出到3.0版本,但是3.0的Cairngorm已经不能被称为框架了,而称为软件开发的一种指导原则,其中包括了“指导原则”、“第三方类库”、“工具”组
Flex4使用Cairngorm2框架
作者:准提道人 ???发表于: 2011-03-16??3:06 ???分类:?FLex
虽然说Cairngorm框架已经出到3.0版本,但是3.0的Cairngorm已经不能被称为框架了,而称为软件开发的一种指导原则,其中包括了“指导原则”、“第三方类库”、“工具”组成,因此如果使用Cairngorm还是应该整合Cairngorm2版本的。
Cairngorm2有两个版本,即普通版和企业版,区别是企业版的数据服务使用的是高收费的?LiveCycle Data Services,而普通版的使用的是Blazeds。因此我们只要集成普通版的就可以了。
首先下载Cairngorm2普通版的SWC包,点击这里。
将下载下的SWF包引入到项目中,建立Cairngorm需要的包,Cairngorm需要7个包,分别是:
1. Business –》业务逻辑 Delegate类和ServiceLocator文件
2.Command -》命令逻辑 Command类
3. Event -》事件类
4. Vo -》放置ValueObject类
5. Model -》 放置Model类
6. View -》放置视图文件
7. Contorller -》放置Control类
Cairngorm 是事件驱动的,具体原理请参考官网文档,或者我以后有时间了也许会总结一下。
本文只介绍Flex整合Cairngorm框架,后台实现不再介绍。下面就开始写具体的代码了,首先我们先把视图创建出来,确定我们要做个什么东西。在view包里面创建一个组件文件,拖进来一个datagrid,几个按钮和label,最后创建出来的样式应该如下:
?
当然现在的视图只有一个样子,什么功能都没有,接下来我们要创建跟这个视图绑定的数据,即Model,在Model包里创建一个as文件,因为我们需要用到数据的分页,因此将这些数据都放到同一个Model里面。代码如下:
|
???? public class UserPageModelLocator implements ModelLocator
|
03
{
|
04
????????private static? var ?_instance:UserPageModelLocator;
|
05
? |
06
public?pageSize:int;
|
07
pageNo:int;
|
08
pageCount:String;
|
09
prevPage:int;
|
10
nextPage:int;
|
11
totalCount:String;
|
12
order:String;
|
13
orderBy:String;
|
14
hasPrev:Boolean;
|
15
hasNext:Boolean;
|
16
result:IList;
|
17
18 |
function?UserPageModelLocator()
|
19
20 |
????????????if ?(_instance !=? null ?) {
|
21
????????????????throw ?new ?CairngormError(CairngormMessageCodes.SINGLETON_EXCEPTION,
|
22
????????????????????"EmployeesModelLocator" );
|
23
????????????}
|
24
? |
25
_instance =?this ;
|
26
}
|
27
28 |
public static?getInstance():UserPageModelLocator{
|
29
if(_instance ==? null ){
|
30
????????????????UserPageModelLocator();
|
31
32 |
return?_instance;
|
33
34 |
}
|
在Cairngorm里面,Model都是单例对象,所以这点要注意。
与视图绑定的数据已经创建好了,接下来要让视图能够工作了,又得提一下Cairngorm的事件驱动了,在Cairngorm里面,所有的操作数据传递等都是由事件进行驱动的,因此我们要创建一个要进行的操作的事件类,首先我希望能够在程序一打开的时候就把第一页的数据全部都取出,所以创建一个获取所有用户的事件类,代码如下:
1
public class GetAllUserEvent extends CairngormEvent |
2
{
|
3
public static const EVENT_GETALLUSER:String =?"getAllUser" 4 |
5 |
GetAllUserEvent(){
|
6
super(GetAllUserControl.EVENT_GETALLUSER);
|
7
8 |
}
|
Cairngorm里的自定义事件都应该继承CairngormEvent类。这个事件被触发了之后要进行什么样的操作呢?这个时候我们要创建控制器了,在Control包里创建一个Contoller类,代码如下:
public class GetAllUserControl extends FrontController
public static const EVENT_GETALLUSER =?GetAllUserControl()
addCommand(GetAllUserControl.EVENT_GETALLUSER,GetAllUserCommand);
9
}
|
继承了Cairngorm的前端控制器,意思是监听这事件,如果这个事件被触发了,我们要执行一向操作,也就是Cairngorm的Command,这个时候我们可以创建Command类了,代码如下:
public class GetAllUserCommand implements ICommand,IResponder
execute(event:CairngormEvent):void
delegate:GetAllUserDelegate =?GetAllUserDelegate(
getAllUserEvent:GetAllUserEvent = GetAllUserEvent(event);
delegate.getAllUser();
result(event:Object):void
model:UserPageModelLocator = UserPageModelLocator.getInstance();
model.pageSize = event.result.pageSize;
model.pageCount = event.result.pageCount;
model.result = event.result.result;
model.pageNo = event.result.pageNo;
model.hasNext = event.result.hasNext;
model.hasPrev = event.result.hasPrev;
model.nextPage = event.result.nextPage;
model.prevPage = event.result.prevPage;
model.order = event.result.order;
model.orderBy = event.result.orderBy;
model.totalCount = event.result.totalCount;
fault(event:Object):void
Alert.show("Somthing is wrong!"
}
可以看出,Command类我们实现了两个接口,分别是ICommand和IResponder,前面一个是Cairngorm的接口,后面一个是Flex中的异同通讯接口。ICommand定义了一个方法execute,就是要执行的内容,这里我们可以看到我们执行的逻辑是什么,当然里面的业务逻辑类我们还没有创建,但是可以看出调用了远程的方法,IResponder有两个接口,分别是result和fault,分别是返回成功和失败后腰调用的方法。在result里,我们将后台返回的结果放入了model里面,这样通过Flex的数据绑定,就可以自动的更新视图的内容了。
现在就只差业务逻辑还没有创建了,在Business包里面包括两方面的内容,一个是要进行的业务逻辑操作即Delegate,一个是ServiceLocator,即远程访问的地址。首先创建ServiceLocator,创建一个mxml文件,内容如下:
<?
xml
?version
=
"1.0"
?encoding
"utf-8"
?>
<cairngorm:ServiceLocator
????xmlns:mx
"http://www.adobe.com/2006/mxml"
xmlns:cairngorm"http://www.adobe.com/2006/cairngorm"
>
mx:RemoteObject?id
"flexSev"
?destination
"flexServlet"
</
mx:RemoteObject
cairngorm:ServiceLocator
>
这里我们创建了一个id为flexServ的RemoteObject,他的Destination为flexServlet。然后我们要创建它的逻辑了,代码:
public class GetAllUserDelegate
private?responder:IResponder
services:Object;
GetAllUserDelegate(responder:IResponder)
.responder = responder;
.services = ServiceLocator.getInstance().getRemoteObject("flexSev"
);
getAllUser():void{
token:AsyncToken = services.findAll();
token.addResponder(responder);
getUserByPageNo(pageNo:int):void{
token:AsyncToken = services.findPrev(pageNo);
token.addResponder(responder);
}
在构造函数里,我们就调用了这个service,这里面有两个方法,一个是获取所有用户,一个是根据页面查找用户,我们现在用的是前面一个方法,后面一个方法在后面的翻页功能时才能用到。
?
到现在为止,Cairngorm所需的所有类都已经创建完毕,但是不是就能够使用了呢?当然不是,没说嘛,刚开始创建视图的时候我们只拉好了界面,其余什么都没做,现在我们要把这些类串联起来,让Cairngorm能够将数据取出来,首先我们想要在程序一打开的时候就把第一页的所有用户取出,则要在createComplete里添加如下方法:
init():void{
getAllUserEvent:GetAllUserEvent =?GetAllUserEvent( );
CairngormEventDispatcher.getInstance().dispatchEvent(getAllUserEvent);
}
我们直接在程序打开的的时候就触发了获取所有用户的事件,这是Controller监听了这个事件,发现被这个事件被触发了,马上调用了获取所有对象的command,command就去调用获取所有对象的业务逻辑Delegate,Delegate返回了结果,把结果放入了Model,这个时候,我们就需要把视图与Model进行绑定,让数据自动更新到视图中,我们需要在datagrid中添加:
dataProvider="{UserPageModelLocator.getInstance().result}"
这样应该可以了吧?其实还不行,为虾米呢?虽然我们在后台调用业务逻辑的时候调用了id为flexServ的remoteObject,但是他怎么知道这个flexServ在哪里呢?所以我们还要把他引入才行,在组件里添加如下:
fx:Declarations>
rds:Services?xmlns:rds
"com.boco.wb.cairngorm.business.demo.*"
/>
router:GetAllUserControl?xmlns:router
"com.boco.wb.cairngorm.control.demo.*"
/>
router:FindPageUserContol?>
现在程序已经完全串联起来,可以使用了。其中还有分页的内容现在就不贴代码了。
现在是不是觉得使用Cairngorm太麻烦了,要建这么多的类行,这么个小功能自己写很简单就写好了,当然,这只是一个小demo,小的演示程序根本不必使用Cairngorm,真正使用时要在大型的项目中,这样才能使程序开发起来更加清晰明了,加快开发速度。
(编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!