pureMVC简单示例及其原理讲解三(View层)
本篇说的是View层,即视图层,在本示例中包括两个部分:MXML文件,即可视控件;Mediator。
可视控件
可视控件由UserForm.mxml(图1)和UserList.mxml(图2)两个文件组成。UserForm.mxml用于添加用户,UserList.mxml显示用户和删除已添加用户。

【图1】

【图2】
先看UserForm.mxml,既然要添加用户,就一定会要一个方法。你还记得么,在上一篇《pureMVC简单示例及其原理讲解——Model层 》中我们提到的UserProxy中有一个ArrayCollection类型的users属性和无返回值的addItem方法,其中users中存储UserVO,addItem方法用来向users中添加UserVO。现在我们既然要在界面通过添加按钮添加用户,我们必然要用到这个方法,但是我们不会在View层直接使用这个方法。因为pureMVC的追求是将MVC分离,而这些逻辑操作我们都会将其放入Command中,即Controller才层。但是在View层,我们也不是没有作为的。我先调一调你的胃口,不要着急,这个作为我们会在本篇接下来的部分讲。先看看userForm.mxml的代码。
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Panel title="Registor" xmlns:mx="http://www.adobe.com/2006/mxml">
- <mx:Metadata>
- [Event('add')]
- </mx:Metadata>
- <mx:Script>
- <![CDATA[
- import mx.controls.Alert;
- import com.superwulei.model.vo.UserVO;
- public static const USER_ADD:String = "add";
- public var user:UserVO;
- /* 添加用户 */
- private function addUser():void {
- user = new UserVO(email.text, password.text);
- dispatchEvent(new Event(USER_ADD));
- }
- private function enableSubmit(u:String, p:String):Boolean {
- return u != '' && p != '';
- }
- ]]>
- </mx:Script>
- <mx:Form>
- <mx:FormItem label="email" required="true">
- <mx:TextInput id="email"/>
- </mx:FormItem>
- <mx:FormItem label="password" required="true">
- <mx:TextInput id="password" displayAsPassword="true"/>
- </mx:FormItem>
- </mx:Form>
- <mx:ControlBar horizontalAlign="right">
- <mx:Button id="sbumitButton" label="添加"
- enabled="{enableSubmit(email.text,password.text)}"
- click="addUser();"/>
- </mx:ControlBar>
- </mx:Panel>
在UserForm.mxml中定义一个Event,并对应的定义一个USER_ADD常量。来看看点击添加按钮后会怎么样?找到submitButton按钮的click事件对应的方法addUser。在addUser方法中,首先要生成一个UserVO对象user,这个user存储的信息就是你在界面上输入的email和密码;此外还要注意,这个UserVO的对象user事先已经声明,且是public的访问修饰符。之所以将user的访问限制设定为公有的,是由于这个user会在其他地方用到,这个其他地方请您关注。
一般的,一个可视控件会对应一个Mediator;但有时候多个可视控件也会对应一个Mediator。本示例中,可视控件和Mediator的关系是前者,即一对一。来看看UserForm.mxml对应的UserFormMediator.as代码。
- package com.superwulei.view
- {
- import com.superwulei.ApplicationFacade;
- import com.superwulei.view.components.UserForm;
- import flash.events.Event;
- import org.puremvc.as3.patterns.mediator.Mediator;
- public class UserFormMediator extends Mediator
- {
- public static const NAME:String = "UserFormMediator";
- public function UserFormMediator(viewComponent:Object)
- {
- super(NAME, viewComponent);
- userForm.addEventListener(UserForm.USER_ADD,onAdd);
- }
- private function get userForm():UserForm{
- return viewComponent as UserForm;
- }
- /* 添加用户监听器 */
- private function onAdd(event:Event):void{
- add();
- }
- /* 添加用户方法 */
- private function add():void{
- sendNotification(ApplicationFacade.USER_ADDED,userForm.user);
- }
- }
- }
在View层,Mediator是pureMVC的核心,其私有变量viewComponent表示一个可视控件,上例中viewComponent表示UserForm,通过userForm属性实现。
看构造器UserFromMediator(...)。首先调用了父类的构造方法;然后给userForm属性加上onAdd监听器,这个userFrom属性是通过getter方法实现的,见get userForm():UserForm。来看onAdd监听器,调用add方法,在add方法中使用了sendNotification方法。刚才我们所说的添加用户的方法不是没有作为,这就是我所谓的有所作为,即“发送通知”。pureMVC中将逻辑控制放在了Controller层,因此在View层就不会有添加用户的代码,但是我们将“添加用户”这个命令以通知的方式发送出去。注意sendNotification方法中携带了两个参数,第一个参数是一个常量,第二个参数是一个UserVO对象。这个常量表示会调用与之对应的Command,这个UserVO对象表示的就是要添加的用户。这个在Controller层会讲到。
UserList.mxml和UserListMediator.as和上面的道理是类似的,在此不多言。以下是UserList.mxml和UserListMediator.as的代码。
- <?xml version="1.0" encoding="utf-8"?>
- <mx:Panel xmlns:mx="http://www.adobe.com/2006/mxml" title="已注册用户">
- <mx:Metadata>
- [Event('delete')]
- </mx:Metadata>
- <mx:DataGrid id="userGrid" dataProvider="{users}">
- <mx:Script>
- <![CDATA[
- import mx.formatters.DateFormatter;
- import com.superwulei.model.vo.UserVO;
- import mx.collections.ArrayCollection;
- public static const USER_DELETE:String = "delete";
- [Bindable]
- public var users:ArrayCollection;
- public var selectUser:UserVO;
- private function deleteUser():void{
- selectUser = userGrid.selectedItem as UserVO;
- dispatchEvent(new Event(USER_DELETE));
- }
- ]]>
- </mx:Script>
- <mx:columns>
- <mx:DataGridColumn dataField="email"/>
- <mx:DataGridColumn dataField="password"/>
- <mx:DataGridColumn dataField="regDate" width="200"/>
- </mx:columns>
- </mx:DataGrid>
- <mx:HBox textAlign="center">
- <mx:Button id="deleteButton" label="删除" click="deleteUser();"/>
- </mx:HBox>
- </mx:Panel>
- package com.superwulei.view
- {
- import com.superwulei.ApplicationFacade;
- import com.superwulei.model.UserProxy;
- import com.superwulei.view.components.UserList;
- import flash.events.Event;
- import org.puremvc.as3.patterns.mediator.Mediator;
- public class UserListMediator extends Mediator
- {
- private var userProxy:UserProxy;
- public static const NAME:String = "UserListMediator";
- public function UserListMediator(viewComponent:Object)
- {
- super(NAME, viewComponent);
- userList.addEventListener(UserList.USER_DELETE,onDelete);
- userProxy = facade.retrieveProxy(UserProxy.NAME) as UserProxy;
- userList.users = userProxy.users;
- }
- private function get userList():UserList{
- return viewComponent as UserList;
- }
- /* 删除用户监听器 */
- private function onDelete(event:Event):void{
- deleteUser();
- }
- /*删除用户方法*/
- private function deleteUser():void{
- sendNotification(ApplicationFacade.USER_DELETE,userList.selectUser);
- }
- }
- }
关于Mediator再补充一下,在每个Mediator中会看到有一个公有的静态的常量字符串,这个字符串用来表示Mediator的类名。同样的在Proxy和Command中你也会看到,这样就可以通过facade的retrieveMediator、retrieveProxy和retieveCommand来检索对象。
关于Model层要记住:一个MXML可视控件对应一个Mediator,Mediator本身不处理操作但它会发送Notification(发送出去的Notification会自动被执行),关于界面上的操作采用监听的方式即addEventLisentner。
pureMVC简单示例及其原理讲解三(View层)的更多相关文章
- pureMVC简单示例及其原理讲解四(Controller层)
本节将讲述pureMVC示例中的Controller层. Controller层有以下文件组成: AddUserCommand.as DeleteUserCommand.as ModelPrepCom ...
- pureMVC简单示例及其原理讲解二(Model层)
本节将讲述Model层. Model层有VO和Mediator组成,非常简单,仅仅包含两个类:UserVO和UserProxy. UserVO中的构造器用于初始化用户的添加(通过email和密码),另 ...
- pureMVC简单示例及其原理讲解五(Facade)
本节将讲述Facade,Proxy.Mediator.Command的统一管家.自定义Facade必须继承Facade,在本示例中自定义Facade名称为ApplicationFacade,这个名称也 ...
- pureMVC简单示例及其原理讲解一(开篇)
pureMVC是一个MVC框架,皆在最大限度的减少MVC间的耦合性.本人刚刚接触pureMVC时感到一头雾水,不知从何入手,也不知道从何学习.好在本人有耐性且能看懂英文技术文档,面向对象的编程能力也比 ...
- Optaplanner规划引擎的工作原理及简单示例(2)
开篇 在前面一篇关于规划引擎Optapalnner的文章里(Optaplanner规划引擎的工作原理及简单示例(1)),老农介绍了应用Optaplanner过程中需要掌握的一些基本概念,这些概念有且于 ...
- SignalR代理对象异常:Uncaught TypeError: Cannot read property 'client' of undefined 推出的结论 SignalR 简单示例 通过三个DEMO学会SignalR的三种实现方式 SignalR推送框架两个项目永久连接通讯使用 SignalR 集线器简单实例2 用SignalR创建实时永久长连接异步网络应用程序
SignalR代理对象异常:Uncaught TypeError: Cannot read property 'client' of undefined 推出的结论 异常汇总:http://www ...
- Websocket - Websocket原理(握手、解密、加密)、基于Python实现简单示例
一.Websocket原理(握手.解密.加密) WebSocket协议是基于TCP的一种新的协议.WebSocket最初在HTML5规范中被引用为TCP连接,作为基于TCP的套接字API的占位符.它实 ...
- 【Redis】三、Redis安装及简单示例
(四)Redis安装及使用 Redis的安装比较简单,仍然和大多数的Apache开源软件一样,只需要下载,解压,配置环境变量即可.具体安装过程参考:菜鸟教程Redis安装. 安装完成后,通过r ...
- CNN(卷积神经网络)原理讲解及简单代码
一.原理讲解 1. 卷积神经网络的应用 分类(分类预测) 检索(检索出该物体的类别) 检测(检测出图像中的物体,并标注) 分割(将图像分割出来) 人脸识别 图像生成(生成不同状态的图像) 自动驾驶 等 ...
随机推荐
- Ceph RBD CephFS 存储
Ceph RBD CephFS 存储 环境准备: (这里只做基础测试, ceph-manager , ceph-mon, ceph-osd 一共三台) 10.6.0.140 = ceph-manag ...
- 深入理解viewport(转)
在移动设备上进行网页的重构或开发,首先得搞明白的就是移动设备上的viewport了,只有明白了viewport的概念以及弄清楚了跟viewport有关的meta标签的使用,才能更好地让我们的网页适配或 ...
- 找礼物(find)
找礼物(find) 题目描述 新年到了,你的好友和你(共K个人)的周围满是礼物,你让你的好友先拿,但是每个人只能拿当前离自己最近的礼物[当然如果有并列的多个礼物离你的距离相等(精确到小数点后四位,所有 ...
- Raspberry Pi 上使用WN725N连接WIFI
系统版本 lee@Lee-RPi ~ $ uname -ar Linux Lee-RPi + # PREEMPT Thu Dec :: GMT armv6l GNU/Linux 这个版本的系统,已经集 ...
- CSS——宽高问题大汇总
1.宽高继承 他们是要属性的,并不是直接就能继承,inherit. 2.浮动的盒子不要给宽,宽度由内容来决定
- 一、什么是hadoop?
一.什么是hadoop 1. 背景 Hadoop为分布式文件系统和计算的基础框架系统,其中包含hadoop程序,hdfs系统等. 2. 名词解释 1.Hadoop, Apache开源的分布式框架. ...
- USB自定义HID设备实现-STM32
该文档使用USB固件库,在其基础上进行了自己的定制,完成了一个USB-HID设备,首先是usb_desc.c文件,里面存放了usb各种描述符的存在 #include "usb_desc.h& ...
- OSD(On Screen Display )技术(转)
源:OSD(On Screen Display )技术 OSD 是 On Screen Display 的缩写,是应用在 CRT/LCD 显示器上,在显示器的荧幕中产生一些特殊的 字形或图形,让使用者 ...
- Android线程之异步消息处理机制(三)——AsyncTask
Android的异步消息处理机制能够很完美的解决了在子线程中进行UI操作的问题,但是为了更加方便我们在子线程中对UI进行操作,Android还提供了另一个很好用的工具,AsyncTask就是其中之一. ...
- FATFS外置UNICODE GBK双向转换码表(转)
源:FATFS外置UNICODE GBK双向转换码表 将UtoG,GtoU双向码表放到存储卡里面实现长文件名,因为FATFS长文件名需要unicode支持, 首先将UtoG.sys,GtoU.sys两 ...