Cairngorm框架的使用记录

 Cairngorm是adobe为flex工程师准备的mvc开源框架,据说与PureMVC一起号称flex届目前最好用的两个mvc框架。随便选了一个,在项目开始的时候选择了Cairngorm作为我的产品的选择,虽然我到现在还读不清楚Cairngorm的发音(现在开源项目的名字越来越生僻)。

Cairngorm可以在官方网站(http://opensource.adobe.com/wiki/display/cairngorm/Downloads )上下载到,其中有bin目录(包含编译好的swc文件),有doc目录(包含使用说明),当然还少不了src目录(包含所有的源码)。

打开src目录,可以看到com.adobe.cairgorm下只有几个目录,代码量并不大,其中主要分为以下几个部分:

business:主要使用的是ServiceLocator类,通过定义ServiceLocator类,可以通过http或是webservice或是remoteObject的方式访问服务器的对象。

将ServiceLocator在应用中定义之后,就可以在项目中使用ServiceLocator.getInstance()[id];的方式来引用定义的服务。在我的项目中只定义了一个RemoteObject的服务作为后台访问的接口,与BlazeDs+Spring结合对后台java容器中的对象进行操作。

commands:主要使用的有ICommand接口与SequenceCommand类。

ICommand接口包含一个execute方法,如果自己写的Command要纳入Cairngorm的管理中,就必须实现ICommand接口。如果该Command与服务器进行交互,则可以让Command再实现Responder接口,即可在onResult方法中获取到远程调用返回值。

SequenceCommand类能够使触发一次事件就执行一系列命令中,需要通过扩展SequenceCommand来得到。

control:Cairngom的控制器就在这个package中,其中所包含的三个类都是必须使用到的。

CairngormEvent:自定义事件的基类

CairngormEventDispatcher:使用单例模式,用来在应用程序中分发自定义的event,代码如下:

CairngormEventDispatcher.getInstance().dispatchEvent( new SelfEvent() );

FrontController:应用程序自定义控制器的基类,用户继承FrontController后通过调用FrontController的addCommend方法来注册自己使用到的业务命令。例如:

public class WideController extends FrontController{

public function WideController(){
addCommand(LoginCommand.USERLOGIN, LoginCommand);
addCommand(LogoutCommand.USERLOGOUT, LogoutCommand);
addCommand(RegisterCommand.USERREGISTER, RegisterCommand);

}

}

addCommand事件将对应的Command注册到FrontController的缓存中去,CairngormEventDispatcher进行分发事件时能够找到对应需要执行的事件。

model:有用到的只有IModelLocator接口了(ModelLocator接口现在已经不建议使用),实现该接口后可以将全局对象都放到 IModelLocator中进行管理,IModelLocator的子类建议使用单例模式(毕竟是管理全局对象的,一个对象只要一个实例就好了)

view:原先是用于管理全局的页面视图,在2.2版以后都不在推荐使用了。

vo:能使用的只有IValueObject接口了(ValueObject接口不建议使用),这个接口并没有强制性要求使用,也没有任何方法,只是建议实现该接口让应用程序中ValueObject在不同的应用层面中传递数据是能有更好的可读性。

其他:CairngormError用于捕获应用程序在使用cairngorm过程中跑出的例外,CairngormMessageCodes为 cairngorm使用到的消息代码,主要为错误代码。这些代码的国际化信息在src下的locale目录里,目前只有en_US的语言,可以自行为消息添加中文。

其实cairngorm框架的代码并不多,只要了解flex的事件机制,谁都可以写出这样的一个mvc框架,cairngorm的事件流程如下:

cairngorm流程图片

以下演示一个登陆操作的实例代码(使用工具为FlexBuilder):

0.将cairngorm包导入应用程序中。创建一个新应用程序teachFlex,右键点击项目选择属性->Flex BuildPath->Library Path,点击Add Swc选择Cairngorm.swc文件即可,完成后点击Ok关闭窗口。

1.创建vo与ModelLocator,并将vo注册到ModelLocator中去。

public class UserVo
{
[Bindable]
public var name:String;
public var password:String;
public var confirmedPwd:String;
}

public class TeachModelLocator implements ModelLocator
{
private static var modelLocator : TeachModelLocator

//当前用户信息
[Bindable]
public var userVo : UserVo;
//此处使用单例模式,全局维护一个ModelLocator
public function TeachModelLocator()
{
if ( modelLocator != null ){
throw new CairngormError(
CairngormMessageCodes.SINGLETON_EXCEPTION, "TeachModelLocator"
);
}
}
public static function getInstance() : TeachModelLocators{
if ( modelLocator == null )
modelLocator = new TeachModelLocator();
return modelLocator;
}

}

这样在用户登录后就可以在整个应用程序全局获取到当前用户信息。

2.通过继承FrontController来创建自己系统的Controller:

public class TeachController extends FrontController
{
public function TeachController()
{
initialiseCommands();
}
public function initialiseCommands() : void {

//TODO 此处用于注册新的命令

}

}

之后需要在application中为controller添加一个引用为了能够在编译时将controller也编译进应用:

<control:TeachController id="controller"></control:TeachController>

3.编写一个登陆command(LoginCommand)与一个登陆event(LoginEvent),并将command注册到FrontController中
LoginCommand:
public class LoginCommand implements ICommand
{
//当前命令id,用于在事件分发时识别该事件
public static const COMMAND_ID:String="login_command";
public var model:TeachModelLocator = TeachModelLocator.getInstance();
public function LoginCommand()
{
}
//具体biz
public function execute(event:CairngormEvent):void
{
var evt:LoginEvent = LoginEvent(event);
if(evt.name=="teacher" && evt.password=="teacher"){
model.userVo = new UserVo();
model.userVo.name = evt.name;
model.userVo.password = evt.password;
Alert.show("登陆成功");
}else{
Alert.show("登陆失败,用户名或密码错");
}
}
}
LoginEvent:
public class LoginEvent extends CairngormEvent
{
//记录传递的用户名与密码
private var _name:String;
private var _password:String;
public function LoginEvent(name:String,password:String)
{
super(LoginCommand.COMMAND_ID);
_name=name;
_password=password;
}
public function get name():String{
return _name;
}
public function get password():String{
return _password;
}
}
在TeachController中的initialiseCommands方法里增加如下代码用于注册LoginCommand命令:
addCommand(LoginCommand.COMMAND_ID, LoginCommand);
Cairngorm架子就搭好了。
4.创建视图,使用cairngorm框架
创建一个名为teachCairngorm的Application,添加代码如下:
<mx:Script>
<![CDATA[
import com.teachFlex.LoginEvent;
import com.adobe.cairngorm.control.CairngormEventDispatcher;
public function login():void{
CairngormEventDispatcher.getInstance().dispatchEvent(new LoginEvent(username.text,password.text));
}
]]>
</mx:Script>
<teachFlex:TeachController id="controller"></teachFlex:TeachController>
<mx:Text text="用户名"/>
<mx:TextInput id="username" />
<mx:Text text="密码"/>
<mx:TextInput id="password" displayAsPassword="true"/>
<mx:Button label="login" click="login()">
</mx:Button>
最后,run application检查事件的效果。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值