大规模应用的开发与MVP设计模式

简介: 原文http://code.google.com/intl/zh-CN/webtoolkit/articles/mvp-architecture.html 开发任何大型应用程序都有其困难,GWT应用程序也不例外。多个开发人员同时工作在同一个代码库中,维护同一模块的功能,很有可能把代码搞乱。为了增强代码的可维护性,我们在项目引进了设计模式来分离各部分的职责。 在多种设计模式可供选择:Pres
原文http://code.google.com/intl/zh-CN/webtoolkit/articles/mvp-architecture.html 

开发任何大型应用程序都有其困难,GWT应用程序也不例外。多个开发人员同时工作在同一个代码库中,维护同一模块的功能,很有可能把代码搞乱。为了增强代码的可维护性,我们在项目引进了设计模式来分离各部分的职责。 

在多种设计模式可供选择:Presentation-abstraction-control, Model-view-controller, Model-view-presenter等等。虽然每种模式有它的好处,我们发现当开发GWT应用程序时,MVP设计模式是首选的,理由有两个。 首先MV设计模式,就像其他的设计模式一样,通过解藕方式来允许多个开发人员同时工作;其次,这种模式使我们能够减少我们使用 GWTTestCase ,由于它依赖于浏览器,而且,利用MVP设计模式后,我们大部分的代码,只需写轻量级(快速)JRE的测试用例(不需要浏览器)。 

这个模式的核心就是把功能分成组件,对于GWT应用,有一个明确的重点就是要求使 视图 尽可能简单,以减少我们使用GWTTestCase测试时对浏览器依赖以及减少花在测试上的总时间。 

一旦你了解这个设计模式这背后的原理。开发一个MVP的应用程序可能变得直接和容易。为了帮助解释这些概念,我们将使用一个简单的联系人的应用作为一个实例。这个应用程序将允许用户查看,编辑和添加联系人到存储在服务器上的联系人列表中。 

首先,我们将引入以下组件: 

    Model 
    View 
    Presenter 
    AppController 


然后我们将研究这些组件如何交互的,交互过程可分为 
    绑定 presenter 与view 
    事件(Events) 与事件总线  (event bus) 
    历史管理(History)和视图切换 
    测试 

Model 
一个包含业务对象模型,并在我们的联系人的应用中,我们有: 
联系人(Contact):一个联系人列表中的一个对象。 为简单起见,这个对象只包含了一个名字,姓氏和电子邮件地址。 在更复杂的应用,这个对象将有更多的属性。 
联系人明细(ContactDetails):仅包含唯一标识符和显示名称。 

View
 
一个视图包含应用程序的所有的UI组件。 这包括任何表格,标签,按钮,文本框等,视图(view)负责UI的布局,对模型(model)并不了解。 就是说视图不知道它正在显示联系人的信息,只是知道它有,例如,3标签,3个TextBox和2个按钮,垂直的组织在一起。视图之间的转换是通过表现层(Presenter)中的历史(History)记录来管理。 

在我们的联系人应用程序的视图有: 
    ContactsView 
    EditContactView 
EditContactView用于添加新的联系人,以及编辑现有的联系人。 

Presenter
 
表现层(Presenter)包括我们联系人应用的所有逻辑,有历史管理、视图转换、以及通过RPC与服务端的数据同步。作为一个通用的原则,每个视图(view)有一个对应的Presenter,用来驱动视图,处理这个视图中的部件产生的事件。 
在我们的例子中,有如下的Presenter 
    ContactsPresenter 
    EditContactPresenter 
EditContactPresenter 可以新增联系人以及编辑存在的联系人。 

AppController 

对于一些不属于任何视图,而是一些应用层面的逻辑,我们引入了一个AppController 组件,这个组件包含历史管理和视图转换。视图转换直接和历史管理相关,下面将针详细介绍。 




本文摘自:

http://whalm2005.javaeye.com/blog/849770

目录
相关文章
|
3月前
|
设计模式 PHP
PHP中的设计模式:单一职责原则在软件开发中的应用
【10月更文挑战第8天】 在软件开发中,设计模式是解决常见问题的经验总结,而单一职责原则作为面向对象设计的基本原则之一,强调一个类应该只有一个引起变化的原因。本文将探讨单一职责原则在PHP中的应用,通过实际代码示例展示如何运用该原则来提高代码的可维护性和可扩展性。
36 1
|
2月前
|
设计模式 前端开发 JavaScript
JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式
本文深入探讨了JavaScript设计模式及其在实战中的应用,涵盖单例、工厂、观察者、装饰器和策略模式,结合电商网站案例,展示了设计模式如何提升代码的可维护性、扩展性和可读性,强调了其在前端开发中的重要性。
35 2
|
2月前
|
设计模式 监控 算法
Python编程中的设计模式应用与实践感悟###
在Python这片广阔的编程疆域中,设计模式如同导航的灯塔,指引着开发者穿越复杂性的迷雾,构建出既高效又易于维护的代码结构。本文基于个人实践经验,深入探讨了几种核心设计模式在Python项目中的应用策略与实现细节,旨在为读者揭示这些模式背后的思想如何转化为提升软件质量的实际力量。通过具体案例分析,展现了设计模式在解决实际问题中的独特魅力,鼓励开发者在日常编码中积极采纳并灵活运用这些宝贵的经验总结。 ###
|
2月前
|
设计模式 开发者 Python
Python编程中的设计模式应用与实践感悟####
本文作为一篇技术性文章,旨在深入探讨Python编程中设计模式的应用价值与实践心得。在快速迭代的软件开发领域,设计模式如同导航灯塔,指引开发者构建高效、可维护的软件架构。本文将通过具体案例,展现设计模式如何在实际项目中解决复杂问题,提升代码质量,并分享个人在实践过程中的体会与感悟。 ####
|
2月前
|
设计模式 存储 数据库连接
PHP中的设计模式:单例模式的深入理解与应用
【10月更文挑战第22天】 在软件开发中,设计模式是解决特定问题的通用解决方案。本文将通过通俗易懂的语言和实例,深入探讨PHP中单例模式的概念、实现方法及其在实际开发中的应用,帮助读者更好地理解和运用这一重要的设计模式。
24 1
|
3月前
|
设计模式 PHP 开发者
PHP中的设计模式:桥接模式的解析与应用
在软件开发的浩瀚海洋中,设计模式如同灯塔一般,为开发者们指引方向。本文将深入探讨PHP中的一种重要设计模式——桥接模式。桥接模式巧妙地将抽象与实现分离,通过封装一个抽象的接口,使得实现和抽象可以独立变化。本文将阐述桥接模式的定义、结构、优缺点及其应用场景,并通过具体的PHP示例代码展示如何在实际项目中灵活运用这一设计模式。让我们一起走进桥接模式的世界,感受它的魅力所在。
|
3月前
|
设计模式 测试技术 持续交付
架构视角下的NHibernate:设计模式与企业级应用考量
【10月更文挑战第13天】随着软件开发向更复杂、更大规模的应用转变,数据访问层的设计变得尤为重要。NHibernate作为一个成熟的对象关系映射(ORM)框架,为企业级.NET应用程序提供了强大的支持。本文旨在为有一定经验的开发者提供一个全面的指南,介绍如何在架构层面有效地使用NHibernate,并结合领域驱动设计(DDD)原则来构建既强大又易于维护的数据层。
43 2
|
3月前
|
设计模式 算法 PHP
PHP中的设计模式:策略模式的深入解析与应用
【10月更文挑战第8天】 在软件开发的浩瀚宇宙中,设计模式如同星辰指引,照亮了代码设计与架构的航道。本文旨在深入探索PHP语境下策略模式(Strategy Pattern)的精髓,不仅剖析其内核原理,还将其融入实战演练,让理论在实践中生根发芽。策略模式,作为解决“如何优雅地封装算法族”的答案,以其独特的灵活性与扩展性,赋予PHP应用以动态变换行为的能力,而无需牵动既有的类结构。
42 2
|
3月前
|
设计模式 缓存 数据库连接
探索PHP中的设计模式:单例模式的实现与应用
在PHP开发中,设计模式是提高代码可复用性、可维护性和扩展性的重要工具。本文将深入探讨单例模式(Singleton Pattern)的基本概念、在PHP中的实现方式以及实际应用场景。单例模式确保一个类仅有一个实例,并提供全局访问点。通过具体代码示例和详细解释,我们将展示如何在PHP项目中有效利用单例模式来解决实际问题,提升开发效率和应用性能。
|
3月前
|
设计模式 开发者 Python
Python编程中的设计模式应用与实践###
【10月更文挑战第18天】 本文深入探讨了Python编程中设计模式的应用与实践,通过简洁明了的语言和生动的实例,揭示了设计模式在提升代码可维护性、可扩展性和重用性方面的关键作用。文章首先概述了设计模式的基本概念和重要性,随后详细解析了几种常用的设计模式,如单例模式、工厂模式、观察者模式等,在Python中的具体实现方式,并通过对比分析,展示了设计模式如何优化代码结构,增强系统的灵活性和健壮性。此外,文章还提供了实用的建议和最佳实践,帮助读者在实际项目中有效运用设计模式。 ###
30 0