翻译 CodeProject 上的一篇文章,对常见的几种表现模式 (Presentation patterns) 进行了说明,并进行对比。原文地址是http://www.codeproject.com/KB/aspnet/ArchitectureComparison.aspx
表现模式 (Presentation patterns) 背景
与用户界面 (UI) 相关的最大的问题就是大量的凌乱的代码,主要是由这两个因素造成的,首先是用户界面包含负责的逻辑用于维护界面相关对象,其次也包含了应用程序状态的维护。表现模式 (Presentation patterns) 就是围绕如何移除用户界面的复杂性,让界面更加简洁和可管理而产生的,下图就是常见表现模式的种类与分类:
用户界面的3大问题:状态 (State) , 逻辑 (Logic) ,同步 (Synchronization)
- 状态 (State) : 状态是用户界面最关心的问题之一。状态是用户界面数据的当前快照,在 Web 应用中,可能是 Session 级别的一个变量,在 Windows 应用中, 则可能只是界面级别的数据。 用户界面包含的状态越多, 则用户界面越复杂。
- 逻辑 (Logic) : 用户界面往往包含界面逻辑,例如维护文本框、组合框或者其它任何界面元素,用户界面中这种逻辑越多,则用户界面越复杂。
- 同步 (Synchronization) : 用户界面通常需要和业务组件协作,因此用户界面需要在界面元素与业务对象之间同步数据,如果用户界面包含的同步任务越多,则用户界面越复杂。
这三大问题与用户界面的关系如下图:
表现设计模式 (Presentation Design Pattern)
表现设计模式有助于解决上面列出的问题, 它的的基本逻辑就是创建一个额外的表现类 (Presenter) ,用来消化用户界面中复杂的逻辑,数据和同步的问题,从而使得用户界面变得简单明了。根据这个类承担责任的多少,决定了表现设计模式的类型,可能是 SC , PV , PM 等,也就是说,这个类的成熟度决定了它将是那种设计模式。
有用的缩写
缩写 | 完整形式 |
V | 视图 (View) 或者用户界面 (UI) |
P | 包含界面逻辑的表现类 (Presenter class which has the UI logic.) |
L | 用户界面逻辑 |
S | 用户界面的状态 |
M | 业务组件或业务对象 |
SC | 监视控制器 (Supervising controller) |
PV | 被动视图 (Passive view) |
PM | 表现模型 (Passive view) |
监视控制器模式 (SC)
- 状态在视图中保存
- 表现类拥有复杂的表现逻辑,只关注简单的界面绑定逻辑,例如 WPF 或 Silverlight 等提供的绑定机制 (Presenter owns the complex presentation logic. Simple UI binding logic is taken care by using binding technologies like WPF binding and Silverlight binding. Anything complex is taken care presenter class. )
- 表现类关注视图
- 视图不关注表现类
- 视图通过数据绑定和业务模型进行关联
被动视图模式 (PV)
- 状态在视图中保存
- 所有的界面逻辑都被包含在表现类中
- 视图和业务模型完全独立,这种情况下需要一些在业务模型和视图之间进行同步数据的工作
- 表现类关注视图
- 视图不关注表现类
表现模型 (PM)
- 表现类包含逻辑
- 表现类包含状态
- 表现类代表抽象的用户界面
- 表现类不关注用户界面
- 视图关注表现类
- 视图与业务模型完全隔离
MVVM
- 继承自表现模型
- 使用 WPF 以及 Silverlight 的绑定机制
MVC
- 没有表现类,有控制器 (Controller)
- 请求首先到达控制器
- 控制器负责绑定视图与业务模型
- 逻辑存在于控制器中
总结与对比
下表是这几种表现模式从状态,逻辑与同步的角度进行的对比
状态 | 逻辑 | 同步 | ||
Supervising controller | ||||
表现类 | X | X | ||
视图 | X | |||
业务模型 | 视图和业务模型之间通过绑定进行连接。 | |||
Passive View | ||||
表现类 | X | X | ||
视图 | X | |||
Presenter model | ||||
表现类 | X | X | ||
视图 | X | |||
MVVM | ||||
表现类 | X | X | ||
视图 | X | |||
使用 WPF 、Silverlight 的数据绑定机制 | ||||
MVC | ||||
控制器 | X | X | ||
视图 | X |
再来一个图的对比
张志敏所有文章遵循创作共用版权协议,要求署名、非商业 、保持一致。在满足创作共用版权协议的基础上可以转载,但请以超链接形式注明出处。
本博客已经迁移到 GitHub , 围观地址: http://beginor.github.io/
本文转自张志敏博客园博客,原文链接:http://www.cnblogs.com/beginor/archive/2010/03/20/1690711.html,如需转载请自行联系原作者