MVP演化论

本文是翻译MVP: Model-View-Presenter The Taligent Programming Model for C++ and Java(Mike Potel)文章的摘要.该文介绍了从MVC到MVP的思想演化过程.

  • SmallTalk编程模型

    • 在该项目中,使用了MVC来实现GUI(graphical user interface)对象.
    • 使用3个抽象来代表一个GUI对象(checkbox/textbox).
      • Model.代表对象对应的底层数据.(checkBox的on-off状态).
      • View.访问Model中的数据,并完成数据的UI展示.
      • Controller.决定用户在View上的交互动作,如何反映到Model中的数据变化.
      • 最后,Model会通知View,数据状态发生了变化,需要View重绘.整个流程结束.
    • 然后,通过继承和自定义基础的model,view,controller基类,来创建GUI对象.
      • 在一个GUI对象中,含有3个紧密关联的部分.
      • 一个复杂元素,可能会含有多个继承类.
      • 整个交互程序都使用MVC来构建.
  • Taligent编程模型
    • 目标是分解MVC的概念到各个组成部分.
    • 首先,分离了Model和View-Controller.后者成为Presenter.
      • 这样,将问题分解为两块:数据管理(Data Management)和用户界面(User Interface).
      • 数据管理.不仅包含了在Model中的数据表现,还包含了数据结构,访问方法,交换协议,持久化,共享,分布性等.
      • 用户界面.不仅包含了如何在屏幕上绘制对象和鼠标键盘事件,还包含了什么操作是被允许的,会有什么样的反馈,如何辨别用户操作.
    • 好处
      • Model被封装,隔离了与View-Controller的关联.

        • 当替换Model中的数据结构时,仍然可以保持既有的Presenter逻辑.
        • 针对同一份Model,可以有多份Presenter进行展示.这样便于并行开发.
        • 避免在修改数据Model时,需要同步修正使用Model的代码.
      • Model支持持久化.
        • 由Model自身来决定Model中的数据的存储方式.
        • 可以自己将数据保存在内存中,可以通过proxy来访问数据库,可以使用Cache机制...
        • 而这一切,对于上层的Presenter是完全透明的.
      • Model支持共享
        • 使用不同的Model来封装相同的远程数据,使得多个用户可以共享同一分数据.
        • 一个用户对数据的更改,所有人都能看到更新.能够多人同步地操作相同的数据.
  • 数据管理的3个问题
  • 用户界面的3个问题
    • Presenter.翻译用户发起的事件和指令,将其匹配到操作Model的对应Commond上.
  • MVP模式
  • MVP编程Framework
  • 抽象的优势
    • 区分Model/View.

      • View独立:同一份数据可以有不同的展示.
    • 区分Selection/Model.
      • Model独立:改变数据的结构时,不会影响数据的使用.同时支持持久化,远程数据库,和共享.
    • 区分Commond/Selection.
      • 命令重用:单个命令可以应用到对同一Model的单个,多个或者所有数据元素的Selection上.
    • 区分Interactor/View.
      • 输入通用化:在不改变程序逻辑或数据的渲染,可以支持不同的菜单,对话框.
    • 区分Presenter/Command-Interactor.
      • 逻辑重用:程序逻辑和算法从特定的显示显示和数据管理细节中抽象出来,可以在不同程序间重用.
    • 整体上.
      • 平台的可移植性.多标准,分布式,层次分割.

MVP演化论,布布扣,bubuko.com

时间: 2024-10-24 20:26:46

MVP演化论的相关文章

MVC,MVP 和 MVVM 的图示 引用地址(http://www.ruanyifeng.com/blog/2015/02/mvcmvp_mvvm.html)

分类: 开发者手册 MVC,MVP 和 MVVM 的图示 作者: 阮一峰 日期: 2015年2月 1日 复杂的软件必须有清晰合理的架构,否则无法开发和维护. MVC(Model-View-Controller)是最常见的软件架构之一,业界有着广泛应用.它本身很容易理解,但是要讲清楚,它与衍生的 MVP 和 MVVM 架构的区别就不容易了. 昨天晚上,我读了<Scaling Isomorphic Javascript Code>,突然意识到,它们的区别非常简单.我用几段话,就可以说清. (题图:

android MVP模式简单介绍

原文 http://zhengxiaopeng.com/2015/02/06/Android%E4%B8%AD%E7%9A%84MVP/ 前言 MVP作为一种MVC的演化版本在Android开发中受到了越来越多的关注,但在项目开发中选择一种这样的软件设计模式需保持慎重心态,一旦确定 使用MVP作为你App的开发模式那么你就最好坚持做下去,如果在使用MVP模式开发过程中发现问题而且坑越来越大,这时你想用MVC等来重新设计的话基 本上就等于推倒重来了.要知道在Android上MVP在现在为止并没有统

Android App的设计架构:MVC,MVP,MVVM与架构经验谈

来源: Android App的设计架构:MVC,MVP,MVVM与架构经验谈 和MVC框架模式一样,Model模型处理数据代码不变在Android的App开发中,很多人经常会头疼于App的架构如何设计: 我的App需要应用这些设计架构吗? MVC,MVP等架构讲的是什么?区别是什么? 本文就来带你分析一下这几个架构的特性,优缺点,以及App架构设计中应该注意的问题. 1.架构设计的目的 通过设计使程序模块化,做到模块内部的高聚合和模块之间的低耦合.这样做的好处是使得程序在开发的过程中,开发人员

浅谈 MVP in Android(转)

我自己写的demo:https://pan.baidu.com/s/1dFImVYD 一.概述 对于MVP(Model View Presenter),大多数人都能说出一二:“MVC的演化版本”,“让Model和View完全解耦”等等.本篇博文仅是为了做下记录,提出一些自己的看法,和帮助大家如何针对一个Activity页面去编写针对MVP风格的代码. 对于MVP,我的内心有一个问题: 为何这个模式出来后,就能被广大的Android的程序员接受呢? 问了些程序员,他们对于MVP的普遍的认识是:“代

【框架篇】mvc、mvp、mvvm使用关系总结

MVC MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑.数据.界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑.MVC被独特的发展起来用于映射传统的输入.处理和输出功能在一个逻辑的图形化用户界面的结构中. 数据关系 View 接受用户交互请求 View 将请求转交给Controller Controller

Android上的MVP:如何组织显示层的内容

MVP(Model View Presenter)模式是著名的MVC(Model View Controller)模式的一个演化版本,目前它在Android应用开发中越来越重要了,大家也都在讨论关于MVP的理论,只是结构化的资料非常少.这就是我写这篇博客的原因,我想鼓励大家多参与讨论,然后把MVP模式运用在项目开发中. 什么是MVP? MVP模式可以分离显示层和逻辑层,所以功能接口如何工作与功能的展示可以实现分离,MVP模式理想化地可以实现同一份逻辑代码搭配不同的显示界面.首先要澄清就是MVP不

MVC、MVP、MVVM、Angular.js、Knockout.js、Backbone.js、React.js、Ember.js、Avalon.js 概念摘录

转自:http://www.cnblogs.com/xishuai/p/mvc-mvp-mvvm-angularjs-knockoutjs-backbonejs-reactjs-emberjs-avalonjs.html MVC MVC(Model-View-Controller),M 是指业务模型,V 是指用户界面,C 则是控制器,使用 MVC 的目的是将 M 和 V 的实现代码分离,从而使同一个程序可以使用不同的表现形式. 交互方式(所有通信都是单向的): View 传送指令到 Contro

谈谈UI架构设计的演化

谈谈UI架构设计的演化 经典MVC 在1979年,经典MVC模式被提出. 在当时,人们一直试图将纯粹描述思维中的对象与跟计算机环境打交道的代码隔离开来,而Trygve Reenskaug在跟一些人的讨论中,逐渐剥离出一系列的概念,最初是Thing.Model.View.Editor.后来经过讨论定为Model.View和Controller.作者自言“最难搞的就是给这些架构组件起名字”. 因为当时的软件环境跟现在有很大不同,所以经典MVC中的概念很难被现在的工程师理解.比如经典MVC中说:“vi

Android架构(一)MVP全解析

前言 关于架构的文章,博主很早就想写了,虽说最近比较流行MVVM,但是MVP以及MVC也没有过时之说,最主要还是要根据业务来选择合适的架构.当然现在写MVP的文章很多,也有很多好的文章,但是大多数看完后还是一头雾水,用最少的文字表述清楚是我一贯的风格(这里小小的装逼一下),所以还是自己总结比较靠谱. 1.回顾MVC 讲到MVP前我们有必要回顾下MVC,MVC(Model-View-Controller,模型-视图-控制器)模式是80年代Smalltalk-80出现的一种软件设计模式,后来得到了广