转自:http://blog.csdn.net/sutaizi/article/details/6588004

pureMVC 是一个轻量级的框架 它在 flex中非常流行(和cairngorm差不多火)

目前几乎已经移植到所有平台上。

下面实现java版得pureMVC搭建

先给大家看总体的层次:

众所周知 pureMVC是一个轻量级的MVC框架 分为 Model ,View ,Controller。这三个是pureMVC的核心。

除此之外pureMVC中含有一个单例模式Facade。facade负责与Model,View,Controller通信。这样就简化了开发的复杂度。

所以首先需要编写单一模式类facade 也就是上图的 ApplicationFacade.java

  1. public class ApplicationFacade extends Facade {
  2. //
  3. private static ApplicationFacade instance = null;
  4. //启动的主程序实例
  5. private PureMVC_Main main ;
  6. /**
  7. *
  8. * @return
  9. */
  10. public static ApplicationFacade getInstance(){
  11. if( instance == null) instance = new ApplicationFacade ();
  12. return instance ;
  13. }
  14. /**
  15. *
  16. */
  17. protected void initializeController() {
  18. trace.d("ApplicationFacade.initController()");
  19. super.initializeController();
  20. registerCommand(NotiName.NOTI_START, StartupCommand.class);
  21. }
  22. /**
  23. *
  24. * @param main
  25. */
  26. public void startup(PureMVC_Main _main) {
  27. trace.d("ApplicationFacade.startup");
  28. this.main = _main;
  29. //发送通知(notification)给控制器 ,通知名称为 NotiName.NOTI_START(这个String是自己定义的)
  30. //sendNotification是用来发送消息的函数 这是一个全局的函数 。
  31. //三个参数为 String 通知名称
  32. //          Object 通知要传递的内容可以是任何对象
  33. //          String 一般默认为null
  34. //这个通知会在 StartCommand.java中被处理。
  35. this.sendNotification(NotiName.NOTI_START, null, null);
  36. }
  37. }

这样保证了静态变量facade只有一个实例instance

而这个getInstance 择有具体的main程序来调用,当调用时 框架就启动了。

同时在main程序启动框架时,需要同时调用startup方法,

startup方法做了这么几件事情

1.将main程序的引用传给了facade

2.注册了控制器startupCommand。

  1. public class StartupCommand extends MacroCommand{
  2. protected void initializeMacroCommand() {
  3. trace.d("PrepStartUpCommand.initializeMacroCommand()");
  4. addSubCommand(PrepModelCommand.class);
  5. addSubCommand(PrepControllerCommand.class);
  6. addSubCommand(PrepViewCommand.class);
  7. }
  8. }

而startupCommand又注册了另外3个控制器,他们的作用分别是

注册代理:

  1. public class PrepModelCommand extends SimpleCommand implements ICommand{
  2. public void execute(INotification noti){
  3. trace.d("PrepModelCommand.execute()");
  4. this.facade.registerProxy(new LoginProxy());
  5. }
  6. }

让Mediator得到页面的引用

  1. public class PrepViewCommand extends SimpleCommand implements ICommand{
  2. public void execute(INotification noti){
  3. trace.d("PrepViewCommand.execute("+ noti.getName() + ")");
  4. this.facade.registerMediator(new LoginMediator(new LoginWindow()));
  5. }
  6. }

还有一个 是保存Controller与Command的映射,注册消息 与Command 当Command需要时 Command会被创建。

  1. public class PrepControllerCommand extends SimpleCommand implements ICommand{
  2. /**
  3. * 这个方法一定会被执行。用来分析传过来的消息(Notification:PureMVC中各个模块传递的信息)
  4. */
  5. @Override
  6. public void execute(INotification noti){
  7. trace.d("PrepComtrollerCommand.excute()");
  8. this.facade.registerCommand(NotiName.NOTI_LOGIN, LoginCommand.class);
  9. }
  10. }

这样框架就启动了。下面来说说登录的例子。

PureMVC 的View分为2个部分 一个是 纯的UI界面,另一个是Mediator模式

这种模式的好处在于他将UI界面(如loginWondow.java--登录界面)中所有的UI组件 比如 button textField ..封装在一起,通过保存UI界面的应用来调用他们。

打个比方就是:

一栋宿舍楼 ,每一间宿舍都是一个UI控件,真个宿舍楼就是一个Mediator,宿舍楼门口有看门的大爷,大爷知道所有宿舍的情况,。

当有人访问宿舍们需要知道具体某间宿舍的情况的时候 他只需要去问门卫大爷。不需要亲自走到那间宿舍。就能知道具体情况。

在Mediator中有2个重要方法:

  1. public String[] listNotificationInterests() {
  2. String[] list = {
  3. NotiName.LOGIN_SUCCESS, NotiName.LOGIN_FAILED
  4. };
  5. return list;
  6. }
  7. @Override
  8. public void handleNotification(INotification noti) {
  9. if (noti.getName().equals(NotiName.LOGIN_SUCCESS)){
  10. trace.d("login success");
  11. }
  12. if (noti.getName().equals(NotiName.LOGIN_FAILED)){
  13. trace.d("login failed " + noti.getBody().toString());
  14. }
  15. }

第一个方法罗列出 要接受的消息名字

第二个方法进行处理消息。

再看以下代码

  1. public LoginMediator(LoginWindow v) {
  2. super(NAME, null);
  3. // TODO Auto-generated constructor stub
  4. this.setViewComponent(v);
  5. view = v;
  6. v.setVisible(true);
  7. v.btnLogin.addActionListener(new ActionListener(){
  8. public void actionPerformed(ActionEvent e) {
  9. // TODO Auto-generated method stub
  10. login();
  11. }
  12. });
  13. }
  14. private void login(){
  15. //得到所有用户登录的信息 就是界面上输入的信息
  16. User user = new User(
  17. view.txtName.getText(),
  18. view.pwdPwd.getText()
  19. );
  20. //将这个信息发送给LoginCommand.java控制器。
  21. //注意这个消息要在 prepControllerCommand.java中注册 建立Mediator到Command的映射关系
  22. sendNotification(NotiName.NOTI_LOGIN,user,null);
  23. }

在Mediator中 处理了所有UI中的事件  比如说为Button添加监听

并且收集数据 (收集 用户名和密码)封装到User中(自动以Object),然后发送消息给Command,把这些数据也发送出去。

此时由于刚才在PrepControllerCommand.java中注册了这个消息 对应的LoginCommand会被激活,处理这个消息。

  1. public class LoginCommand extends SimpleCommand implements ICommand {
  2. public void execute(INotification noti) {
  3. //根据对应的消息名字处理相关逻辑 并且调用后台(比如数据库)
  4. if (noti.getName().equals(NotiName.NOTI_LOGIN) == true) {
  5. User user = (User)noti.getBody();
  6. LoginProxy lp = new LoginProxy();
  7. if(checkLogin(user))
  8. lp.login(user);
  9. else
  10. sendNotification((String) NotiName.LOGIN_FAILED,"User name should not be empty!",null);
  11. }
  12. }
  13. private boolean checkLogin(User u){
  14. //username should not be empty
  15. if(u.getUsername() == null )return false;
  16. return true;
  17. }
  18. }

这里处理这个消息买并且调用Model中的Proxy。Proxy负责进行数据操作,比如得到远程服务器的数据,或者与数据库进行交互。

处理完数据后 吧数据通过消息(Notification)发送给Mediator 整个流程就完成了。

  1. public class LoginProxy extends Proxy{
  2. public static final String NAME = "LoginProxy";
  3. public LoginProxy() {
  4. super(NAME, null);
  5. trace.d("LoginProxy.LoginProxy()");
  6. }
  7. public void login(User user) {
  8. // TODO Auto-generated method stub
  9. //这里用来进行数据库操作 将User信息给数据库 ,并且返回信息。,返回方式 也是使用Notification
  10. //这里发送的Notification在Mediator中(handleNotification方法)处理 。
  11. //方便起见。,我这里就不写数据库操作了。
  12. if(user.getUsername().equals("young") )
  13. sendNotification(NotiName.LOGIN_SUCCESS,"login success!",null);
  14. else
  15. sendNotification(NotiName.LOGIN_FAILED,"login error ,wrong username",null);
  16. }
  17. }

Mediator在HandleNotification中处理Proxy发来的消息

pureMVC java版搭建流程的更多相关文章

  1. 【转】搭建Java版WebService

    原文地址:http://www.cnblogs.com/jasoncc/archive/2011/12/22/2296052.html Hi,大家好! 今天主要和大家分享,如何搭建一个Web服务,做A ...

  2. SpringMVC框架搭建流程(完整详细版)

    SpringMVC框架搭建流程 开发过程 1)配置DispatcherServlet前端控制器 2)开发处理具体业务逻辑的Handler(@Controller. @RequestMapping) 3 ...

  3. 第八篇 :微信公众平台开发实战Java版之如何网页授权获取用户基本信息

    第一部分:微信授权获取基本信息的介绍 我们首先来看看官方的文档怎么说: 如果用户在微信客户端中访问第三方网页,公众号可以通过微信网页授权机制,来获取用户基本信息,进而实现业务逻辑. 关于网页授权回调域 ...

  4. FILEBEAT+ELK日志收集平台搭建流程

    filebeat+elk日志收集平台搭建流程 1.         整体简介: 模式:单机 平台:Linux - centos - 7 ELK:elasticsearch.logstash.kiban ...

  5. SSH(Struts2+Spring+Hibernate)框架搭建流程<注解的方式创建Bean>

    此篇讲的是MyEclipse9工具提供的支持搭建自加包有代码也是相同:用户登录与注册的例子,表字段只有name,password. SSH,xml方式搭建文章链接地址:http://www.cnblo ...

  6. 第七篇 :微信公众平台开发实战Java版之如何获取微信用户基本信息

    在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的.对于不同公众号,同一用户的openid不同). 公众号可通过本接口来根据O ...

  7. 第六篇 :微信公众平台开发实战Java版之如何自定义微信公众号菜单

    我们来了解一下 自定义菜单创建接口: http请求方式:POST(请使用https协议) https://api.weixin.qq.com/cgi-bin/menu/create?access_to ...

  8. 第五篇 :微信公众平台开发实战Java版之如何获取公众号的access_token以及缓存access_token

    一.access_token简介 为了使第三方开发者能够为用户提供更多更有价值的个性化服务,微信公众平台 开放了许多接口,包括自定义菜单接口.客服接口.获取用户信息接口.用户分组接口.群发接口等, 开 ...

  9. 第二篇 :微信公众平台开发实战Java版之开启开发者模式,接入微信公众平台开发

    第一部分:微信公众号对接的基本介绍 一.填写服务器配置信息的介绍 登录微信公众平台官网后,进入到公众平台后台管理页面. 选择 公众号基本设置->基本配置 ,点击“修改配置”按钮,填写服务器地址( ...

随机推荐

  1. mysql5.7.14 配置

    1. 下载并解压 zip包 2.将解压后的目录 bin  配置到path中 3.修改my-default.ini 文件名为my.ini 4.配置my.ini [mysql] #设置mysql客户端默认 ...

  2. 关于C++中的重定位

    "标准库定义了4个IO对象,处理输入时使用命名为cin的istream类型对象,这个对象也成为标准输入.处理输出时使用命名为cout的ostream类型对象,这个对象也称为标准输出.标准库还 ...

  3. 转:详解JMeter正则表达式(1)

    1.概览 JMeter中包含范本匹配软件Apache Jakarta ORO .在Jakarta网站上有一些关于它的文档,例如a summary of the pattern matching cha ...

  4. “System.BadImageFormatException”类型的未经处理的异常在 PurchaseDevices.Access.dll 中发生 其他信息: 未能加载文件或程序集“System.Data.SQLite, Version=1.0.66.0, Culture=neutral, PublicKeyToken=db937bc2d44ff139”或它的某一个依赖项。试图加载格式不正确

    引用sqlite的程序集时,有时会报如下异常:  "System.BadImageFormatException"类型的未经处理的异常在 PurchaseDevices.Acces ...

  5. 一个突发性的误解C# 引用类型

    最近再看IOCP,结果里面的一个赋值过程,造成了误解. test t1 = new test(); test t2 = new test(); test t4 = new test(); t1= t2 ...

  6. [妙味JS基础]第七课:运算符、流程控制

    知识点总结 &&(与).||(或).!(非) 与: alert(20 && 20>100) => false alert(20 && 20& ...

  7. js 对象 视频 插入元素

    <!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8" ...

  8. linux php安装

    Linux下配置安装PHP环境 参考别人的做法,遇到问题上网查,下面就是安装步骤. 一.安装Apache2.2.221.到官网下载  http://httpd.apache.org/download. ...

  9. 【Python@Thread】thread模块

    一.关于Python多线程 Python解释器中可以同时运行多个线程,但是再任意时刻只能有一个线程在解释器运行. Python虚拟机的访问是由全局解锁器(GIL)控制的,由GIL保证同时只有一个线程的 ...

  10. digitalocean最新优惠码赠送10美元

    digitalocean是我非常喜欢的vps服务商,目前手头还有十来个digitalocean vps服务器.用了三年多digitalocean后,我发现digitalocean一点小技巧.比如,如果 ...