`
jakielong
  • 浏览: 229256 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Cairngorm初学者入门教程 第六节--Cairngorm中Command利用Delegate与Service连接

    博客分类:
  • Flex
阅读更多

 

在上一节,我们利用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 “,可以参考這裡

    代码如下:

     

    <?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。

     

    代码如下:

     

    package org.rianotes.CairngormSample.business
    
    {
    
        import com.adobe.cairngorm.business.ServiceLocator;
    
      
    
        import mx.rpc.IResponder;
    
      
    
        import org.rianotes.CairngormSample.vo.User;
    
      
    
        public class LoginDelegate {
    
      
    
            private var responder:IResponder;
    
            private var service:Object;
    
      
    
            public function LoginDelegate(responder:IResponder) {
    
      
    
                this.responder = responder;
    
      
    
                //透過ServiceLocator取得連接Service的方式
    
                this.service = ServiceLocator.getInstance().getRemoteObject("Remoting_Services");
    
      
    
            }
    
      
    
            public function login(loginAttempt:User):void{
    
                //這部份要跟Server端Remoting Service 的名字相同傳入值型態也要相同
    
                var call:Object = service.login(loginAttempt);
    
      
    
                //處理伺服器的傳回值
    
                call.addResponder( responder );
    
      
    
            }
    
      
    
        }
    
    }
    

     

     为了传送账号和密码,所以也要针对Value object作修改

    User-Value object

    package org.rianotes.CairngormSample.vo
    
    {
    
        //.NET 那邊User.cs的 namespace
    
        [RemoteClass(alias="Remoting.Objects.User")]
    
        public class User
    
        {
    
            public var UserID:String;
    
            public var Password:String;
    
            public var Email:String;
    
      
    
            public function User(){
    
      
    
            }
    
      
    
        }
    
    }
     然后在LoginCommand中加入Responder要用到的result,fault function

     

    代码如下:

    package org.rianotes.CairngormSample.commands
    
    {
    
        import com.adobe.cairngorm.commands.ICommand;
    
        import com.adobe.cairngorm.control.CairngormEvent;
    
      
    
        import mx.controls.Alert;
    
        import mx.rpc.IResponder;
    
      
    
        import org.rianotes.CairngormSample.business.LoginDelegate;
    
        import org.rianotes.CairngormSample.events.LoginEvent;
    
        import org.rianotes.CairngormSample.model.ViewModelLocator;
    
      
    
        //加入IResponder 的Interfac才會呼叫result,falut ↓↓↓           
    
        public class LoginCommand implements ICommand , IResponder{
    
      
    
            public var model:ViewModelLocator = ViewModelLocator.getInstance();
    
      
    
            public function LoginCommand(){
    
      
    
            }
    
      
    
            //ICommand Interface function
    
            public function execute(event:CairngormEvent):void{
    
      
    
                var loginEvent:LoginEvent = event as LoginEvent;
    
          
    
                var delegate:LoginDelegate = new LoginDelegate(this);
    
                delegate.login(loginEvent.loginAttempt);
    
      
    
            }
    
      
    
            //delegate.login 成功取得回傳時做的function
    
            public function result( event :Object):void{
    
                if(event.result == true)
    
                {
    
                    model.workflowState = ViewModelLocator.MAIN_SCREEN;
    
                }else
    
                {
    
                    mx.controls.Alert.show("請確認帳號密碼是否正確!?");
    
                }
    
            }
    
      
    
            //delegate.login 失敗時做的function
    
            public function fault( event :Object):void{
    
                trace("連線錯誤")
    
            }
    
        }
    
    }
    

     LoginView.mxml也要做部分修改,代码如下:

    <?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

    代码如下:

    <?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>
     

     

    分享到:
    评论

    相关推荐

      Cairngorm入门教程整合spring

      在教程的最后,作者强调了本教程的目的是帮助初学者入门,更深层次的内容需要读者自行学习和探索。 通过以上的知识点,可以看出Cairngorm是一个功能丰富的框架,尤其适合于构建复杂的企业级Flex应用程序。它通过...

      Flex开发框架cairngorm入门实例教程

      4. **服务(Service)/命令(Command)**:虽然在提供的内容中没有直接涉及,但Cairngorm通常使用命令模式处理业务逻辑。当控制器接收到事件后,会调用相应的Command来执行业务逻辑,例如保存新添加的图书到数据库。...

      [cairngorm入门]introducing_cairngorm.pdf

      ### Cairngorm框架入门知识点详解 #### 一、Cairngorm框架简介 - **定义与背景**:Cairngorm是一种专为Adobe Flex应用程序设计的模型-视图-控制器...对于初学者来说,掌握这些基本概念和技术点是非常重要的第一步。

      Flex开发框架cairngorm入门实例教程.rar

      在“flex cairngorm入门实例教程”中,你可能会学到如何设置项目环境,引入Cairngorm库,创建和配置模型、控制器、命令以及事件监听器。教程可能还会涵盖如何使用Service Locator来注入依赖,以及如何使用...

      Cairngorm框架配置

      ### Cairngorm框架配置详解 #### 一、Cairngorm框架概述 Cairngorm是一种专门为Adobe Flex设计的模型-视图-控制器(Model-View-Controller, MVC)架构模式框架。它通过清晰地分离应用逻辑,使得开发更加模块化、可...

      Flex之使用Cairngorm(3) - Command & Event

      总结起来,Cairngorm通过Command模式解耦了视图和业务逻辑,利用Event机制实现了组件间的通信,借助ModelLocator集中管理数据模型,结合ServiceLocator简化服务的使用。在"UserManagerDemo"这样的应用中,这些概念和...

      cairngorm简单入门实例(结合spring+ibatis)

      学习这个实例,开发者可以了解到如何在实际项目中应用Cairngorm框架,如何将Flex客户端与Spring+iBatis服务端进行交互,以及如何通过事件驱动的方式组织代码,提升项目的可维护性。 总之,这个入门实例为开发者提供...

      Cairngorm例子

      6. **Observer**:观察者模式在Cairngorm中扮演重要角色,允许组件订阅和监听模型的变化。当模型状态改变时,会通知所有相关的观察者。 7. **Presentation Model**(可选):虽然不是Cairngorm的一部分,但MVVM...

      cairngorm中文版

      在提供的压缩包文件中,"Cairngorm中文版.pdf"和"Cairngorm中文版"很可能是对Cairngorm框架的详细中文教程和实例,对于初学者来说,是学习和理解Cairngorm的宝贵资源。通过深入学习这些资料,开发者可以更好地掌握...

      Cairngorm开发文档中文版

      在Cairngorm中,它主要用来查找和实例化Command对象。 8. **商店(Store)**:商店是另一种模式,用于集中管理和访问模型对象。它允许组件以声明式的方式获取模型数据,而无需直接引用模型。 9. **命令工厂...

      Cairngorm.swc+Cairngorm+开发文档中文版.rar 套装

      这个“Cairngorm.swc+Cairngorm+开发文档中文版.rar”套装提供了一个完整的Cairngorm框架,以及相关的中文开发文档,对于初学者和经验丰富的开发者来说都是一个宝贵的资源。 Cairngorm的核心设计理念是基于Model-...

      Flex轻量级开发框架-Cairngorm介绍

      本文将深入探讨Cairngorm框架的核心概念、架构以及关键组件,旨在帮助开发者理解如何有效利用该框架。 #### 二、Cairngorm框架概述 Cairngorm是Adobe官方推荐的一个轻量级Flex开发框架,主要基于MVC(Model-View-...

      Flex3/4 Cairngorm框架 入门 源码 主要是登陆注册功能。

      在Cairngorm中,控制器通常实现为命令(Command)类,它们监听特定事件,执行相应的业务逻辑,并可能更新模型或触发其他命令。 4. **服务定位器(Service Locator)**:提供对应用程序服务的全局访问,例如远程服务...

      Flex Cairngorm内部培训教程

      Cairngorm提供了一个Responder接口,用于处理服务调用的结果,以及ServiceLocator单例类,用于获取定义在XML文件中的服务实例。 2. **Command(命令部分)**:命令模式是Cairngorm的核心组件,负责处理用户交互和...

      flex-Cairngorm框架

      - Command:命令类是Cairngorm中的主要控制逻辑载体,用于处理业务逻辑和事件。当用户触发事件时,Command被创建并执行。 - Proxy:代理类负责与服务器通信,封装数据访问,使得模型和控制器能专注于业务逻辑。 -...

      Cairngorm deepdive

      Cairngorm的第一个版本是在Flex出现之前为Flash开发的,当时主要包含Service Locator和服务辅助器(View Helper)。其中,服务辅助器主要用于管理Flash应用程序中的会话对象,而Service Locator则提供了一个单一入口...

      Cairngorm学习文档

      开发者可以下载Cairngorm库,创建新的Flex项目,然后按照MVC模式组织代码,利用Cairngorm框架中的组件进行事件处理、服务调用和数据管理。 通过这个学习文档,开发者不仅可以了解Cairngorm的基本结构,还能掌握如何...

      flex Cairngorm 实例

      Flex Cairngorm实例详解 Flex Cairngorm框架是Adobe Flex应用程序开发中的一个流行MVC(Model-View-Controller)框架,它提供了一种结构化的方式来组织复杂的Flex项目,以实现可维护性和可扩展性。本实例将深入探讨...

      Cairngorm实例教程

      6. **Proxy**:Proxy是Cairngorm中处理数据访问的组件,它负责与服务器进行通信,获取或更新数据。通常,这些操作会通过HTTPService或WebService组件完成。 7. **Presentation Components**:这些是Flex UI组件,...

    Global site tag (gtag.js) - Google Analytics