声明:本文转载地址为http://www.cnblogs.com/GFantasy/
在上一节,我们利用FrontController 去映射 Event与Command
在这一节我们主要针对Command这部分动作做介紹。在RIA应用程序中,不可或缺的部份就是跟后台服务器连接进行数据传递。Command通过Delegate去做Services的部份(包含Remoting,WebServices,…等)
Command: 操作Cairngorm Business以及呼叫Cairngorm Delegates,这些回传所取得的资料Command会再将它更新到Model Locator
Delegate: 由Command所产生,将远程呼叫(RPC:remote procedure calls[HTTP, Web Services, etc])实例化,并将结果传回给Command。
Service:用来定义连接Server端的呼叫(RPC:remote procedure calls[HTTP, Web Services, etc]),来获取远程数据。
在Delegate中我们会作一个call service的部份,而Services相关的定义与设定,就纪录在Service Locator。
延续上一个项目,我们修改LoginCommand的部份要通过Delegate去做Remoting,呼叫Server端 login function,去数据库查看判断账号密码是否正确。
所以我们先在项目中新增business文件夹。
新增两个文件,一个是Service.mxml组件。用来定义纪录可以使用的Services。
因为组件的类型不是內建,所以先随便选一个再改mxml的內容
这里示范的是使用搭配.NET Remoting的Freeware ” FluorineFx “,可以参考這裡。
代码如下:
<!--
Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/
--><?xml version="1.0" encoding="utf-8"?>
<cairngorm:ServiceLocator
xmlns:mx="http://www.adobe.com/2006/mxml"
xmlns:cairngorm="com.adobe.cairngorm.business.*">
<!-- Login Service -->
<mx:RemoteObject
id="Remoting_Services"
source="Remoting.Services"
destination="fluorine"
showBusyCursor="true">
<mx:method name="login" />
</mx:RemoteObject>
</cairngorm:ServiceLocator>
另一个是LoginDelegate.as类,用来连接Service,并将取得的资料回传给Command。
代码如下:
01 |
package org.rianotes.CairngormSample.business
|
03 |
import com.adobe.cairngorm.business.ServiceLocator;
|
05 |
import mx.rpc.IResponder;
|
07 |
import org.rianotes.CairngormSample.vo.User;
|
09 |
public class LoginDelegate {
|
11 |
private var responder:IResponder;
|
12 |
private var service: Object ;
|
14 |
public function LoginDelegate(responder:IResponder) {
|
16 |
this .responder = responder;
|
19 |
this .service = ServiceLocator.getInstance().getRemoteObject( "Remoting_Services" );
|
23 |
public function login(loginAttempt:User): void {
|
25 |
var call: Object = service.login(loginAttempt);
|
28 |
call.addResponder( responder );
|
为了传送账号和密码,所以也要针对Value object作修改
User - Value object
01 |
package org.rianotes.CairngormSample.vo
|
04 |
[RemoteClass(alias= "Remoting.Objects.User" )]
|
07 |
public var UserID: String ;
|
08 |
public var Password: String ;
|
09 |
public var Email: String ;
|
11 |
public function User(){
|
然后在LoginCommand中加入Responder要用到的result,fault function
代码如下:
01 |
package org.rianotes.CairngormSample.commands
|
03 |
import com.adobe.cairngorm.commands.ICommand;
|
04 |
import com.adobe.cairngorm.control.CairngormEvent;
|
06 |
import mx.controls.Alert;
|
07 |
import mx.rpc.IResponder;
|
09 |
import org.rianotes.CairngormSample.business.LoginDelegate;
|
10 |
import org.rianotes.CairngormSample.events.LoginEvent;
|
11 |
import org.rianotes.CairngormSample.model.ViewModelLocator;
|
14 |
public class LoginCommand implements ICommand , IResponder{
|
16 |
public var model:ViewModelLocator = ViewModelLocator.getInstance();
|
18 |
public function LoginCommand(){
|
23 |
public function execute(event:CairngormEvent): void {
|
25 |
var loginEvent:LoginEvent = event as LoginEvent;
|
27 |
var delegate:LoginDelegate = new LoginDelegate( this );
|
28 |
delegate.login(loginEvent.loginAttempt);
|
33 |
public function result( event : Object ): void {
|
34 |
if (event.result == true )
|
36 |
model.workflowState = ViewModelLocator.MAIN_SCREEN;
|
39 |
mx.controls.Alert.show( "請確認帳號密碼是否正確!?" );
|
44 |
public function fault( event : Object ): void {
|
LoginView.mxml也要做部分修改,代码如下:
<!--
Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/
--><?xml version="1.0" encoding="utf-8"?>
<mx:VBox xmlns:mx="http://www.adobe.com/2006/mxml"
horizontalAlign="right" xmlns:components="org.rianotes.CairngormSample.view.components.*">
<mx:Script>
<![CDATA[
import org.rianotes.CairngormSample.vo.User;
import org.rianotes.CairngormSample.events.LoginEvent;
import org.rianotes.CairngormSample.model.ViewModelLocator;
[Bindable]
private var model:ViewModelLocator = ViewModelLocator.getInstance();
private function login(e:MouseEvent):void{
var user:User = new User();
user.UserID = ti_UserID.text;
user.Password = ti_Password.text;
var loginEvent:LoginEvent = new LoginEvent(user);
//發送Login Event
loginEvent.dispatch();
}
]]>
</mx:Script>
<mx:Form borderStyle="solid" width="100%">
<mx:FormItem label="UserID :" width="100%">
<mx:TextInput id="ti_UserID" width="100%"/>
</mx:FormItem>
<mx:FormItem label="Password: " width="100%">
<mx:TextInput id="ti_Password" width="100%"/>
</mx:FormItem>
</mx:Form>
<mx:Button label="Login" click="login(event)" />
</mx:VBox>
最后我们在Main.mxml中加入Service
代码如下:
<!--
Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/
--><?xml version="1.0" encoding="utf-8"?>
<mx:Application
xmlns:mx="http://www.adobe.com/2006/mxml"
xmlns:view="org.rianotes.CairngormSample.view.*"
layout="absolute" xmlns:control="org.rianotes.CairngormSample.control.*" xmlns:business="org.rianotes.CairngormSample.business.*">
<mx:Script>
<![CDATA[
import org.rianotes.CairngormSample.model.ViewModelLocator;
[Bindable]
private var model:ViewModelLocator = ViewModelLocator.getInstance();
]]>
</mx:Script>
<!--Cairngorm FrontController :讓app中擁有SampleController-->
<control:SampleController id="controller" />
<!--Cairngorm Services-->
<business:Services id="services" />
<mx:ViewStack id="vsMain" width="100%" height="100%"
selectedIndex="{model.workflowState}">
<!--第0個View-->
<view:LoginView />
<!--第1個View-->
<view:MainView />
</mx:ViewStack>
</mx:Application>
分享到:
相关推荐
Flex开发框架cairngorm入门实例教程,有需要的人可以看一下
1 1 跟我StepByStep学FLEX教程------概述(原创) ...1 41 跟我StepByStep学FLEX教程------Cairngorm之Command部分 1 42 跟我StepByStep学FLEX教程------版权声明 1 43 跟我StepByStep学FLEX教程------贵在坚持
cairngorm整合spring+hibernate,里面描述的狠清晰,一看就懂
Flex MVC框架cairngorm 入门
Cairngorm本身並不是一個完整的企業應用,它只提供一個開發的體系,讓開發者遵循這個體系開發出一個結構清暫,解耦良好的程序代碼從而提高程序的維護和擴展。 Cairngorm這個體系包括以下六個部分: Business(业务...
Cairngorm例子Cairngorm例子Cairngorm例子Cairngorm例子
Cairngorm is the lightweight micro-architecture for Rich Internet Applications built in Flex or AIR. A collaboration of recognized design patterns, Cairngorm exemplifies and encourages best-practices ...
什么是Cairngorm,内部MVC结构,Cairngorm的各个部分
Cairngorm是Abode推出的Flex RIAs框架,其实...Command(命令):调用Cairngorm Delegate或其它Command,并更新Model; Delegate(委托):实例化RPC(远程过程调用)并将其结果返回给Command; Business(业务):定义RPC。
flex cairmgorm入门实例教程。
前台FLex工程(单独工程Cairngorm)使用Cairngorm框架与后台java工程(FLexToJava)进行数据交互。功能点: ①flex提交表单保存到数据库; ②flex向后台请求,后台返回List集合,flex将集合填充到combox 附带:...
cairngorm-2.2.2.swc Flex中的一款框架
cairngorm框架是flex界的mvc框架,传统的flex开发方法开发的代码难以维护。 这个是cairngorm的中文版入门讲解
绝对是Cairngorm框架入门的好Demo.下载后记得评分!
一个简单的cairngorm入门实例,结合了spring和ibatis。内含说明文档
Flex框架Cairngorm经典案例源码 完全掌握Cairngorm
cairngorm.swc供需要的朋友急用
Cairngorm框架在Flex开发中的应用研究
flex框架之Cairngorm框架,一个用Cairngorm与后台通信实例
Cairngorm开发例子 利于初学者学习