MVP模式和MVVM模式
MVP模式
模型-视图-表示器,也就是MVP模式。是mvc模式的一种衍生模式,专注于改进表示逻辑。
与MVC不同,来自view的调用将委托给presenter(表示器),表示器通过接口与view对话。
MVP中的view是被动的,里面包含一点代码逻辑或者零逻辑,我们专业的说:这个view是很轻的。
MVP的原理:view进行请求,表示器执行任何与用户请求有关的工作,并将数据回送给它们。表示器检索数据并且操作数据,并且确定应该如何在view中显示这些数据。model模型改变时,是表示器收到通知,然后更新view,因此表示器要订阅model。在这种模式中,没有直接数据绑定的概念了。
具有非常复杂的view和大量用户交互的应用程序可能不适合MVC模式,因为这样会依赖多个控制器。但是在mvp中,所有这些复杂的逻辑可以封装在一个表示器中,这可以大大简化维护工作。
Backbone既可以理解成mvc模式,也可以理解成mvp模式,我们暂且把backbone归结为mv*模式。
MVVM模式
模型-视图-视图模型是一种基于MV*的架构模式,它试图更清晰的将用户界面开发从应用程序的业务逻辑与行为中分离。
为此,很多这种模式的实现都要利用声明式数据绑定来实现将view工作从其他层分离。
这有助于在同一个代码库中UI和开发工作的同时进行。UI开发人员在HTML编写中,编写与viewmodel的绑定,业务逻辑的开发人员编写model和viewmodel。
MVVM中的model
model保存着信息,但是通常不处理行为,它们不会格式化信息或影响数据在浏览器中显示的方式。数据格式化是由view来处理的,而行为被认为是业务逻辑,应该封装在与model交互的另一层中viewmodel中。
MVVM中的view
view实际上仅仅是与用户进行交互的。但是MVVM中的view包含数据绑定,事件和行为,并且需要对viewmodel有了解。虽然,这些东西都可以被映射到属性中,但view仍然负责处理viewmodel的事件。
我们要牢记:view并不负责处理状态,它仅仅是让状态与viewmodel保持同步。
MVVM中的viewmodel
可以将viewmodel作为一个专门的controller,它将model信息转变为view信息,同时还将命令从view传递到model。
view和viewmodel之间通过数据绑定和事件进行通信。
view处理自己的用户界面事件,必要时将它们映射到viewmodel。
model和viewmodel上的属性通过双向数据绑定进行同步和更新。
viewmodel可以为了数据绑定而暴露model或model属性,也可以包含接口,用于获取和操作view中暴露的属性。
总结:mvp和mvvm都是mvc的衍生品。
在mvc中,view位于架构之上,与controller相邻,model位于controller之下,因此view了解controller,controller了解model。view可以直接访问model。
在mvp中,controller的作用被presenter所替代。表示器与view位于同一位置,表示器监听view和model的事件。
在mvvm中,我们可以创建model特定于view的子集,也就是说,我们无需向view暴露整个model。view可以绑定到viewmodel上的属性,而属性会将model所包含的数据暴露给view。
在我们实际的开发中,是使用MV*模式的backbone还是使用MVVM模式的angularjs,Backbone的优势在于它易于与RESTful服务相集成。而angularjs重点关注自动化UI绑定。个人发现angularjs更适用于小型应用程序,Backbone适合创建大型应用程序。但是仁者见仁智者见智,具体情况具体对待。
加油!
MVP模式和MVVM模式的更多相关文章
- 对MVC模式与MVVM模式的认识
MVC模式与MVVM模式目的一样,主要是分离模型(model)和视图(view),具体介绍如下. 名词介绍 MVC模式:指的是模型(Model)-- 视图(View)-- 控制器(Controller ...
- MVP模式与MVVM模式
1.mvp模式(Model层 Presenter层 View 层) Model层 :数据层(ajax请求) Presenter层:呈现层,view逻辑相关的控制层,控制层可以去调Model去发ajax ...
- 浅谈MVC模式与MVVM模式的区别
MVC模式: M:Model(数据模型),用于存放数据 V:View(视图),也就是用户界面 C:Controller是Model和View的协调者,Controller把Model中的数据拿过来给V ...
- MVC模式 和 MVVM模式
MVC模式 模型 - 视图 - 控制器或MVC,MVC是普遍的叫法,是一种软件设计模式,用于开发Web应用程序.模型- 视图 - 控制器模式是由以下三部分组成: 模型/Model - 一个负责维护数据 ...
- MVC模式和MVVM模式简单理解
相信这是两个耳熟能详的词了,MVC广泛的用到了java的各种框架当中,比如Struts2, SpringMVC等,作为B/S架构开发,MVS模式也是我们必须掌握的. mvc一步一步演化之后有了现在的M ...
- Android mvp模式、mvvm模式
MVC和MVP的区别2007年08月08日 星期三 上午 09:23 MVC和MVP到底有什么区别呢? 从这幅图可以看到,我们可以看到在MVC里,View是可以直接访问Model的!从而,View里会 ...
- [vue]mvc模式和mvvm模式及vue学习思路(废弃)
好久不写东西了,感觉收生疏了, 学习使用以思路为主, 记录笔记为辅作用. v-if: http://www.cnblogs.com/iiiiiher/p/9025532.html v-show tem ...
- MVC、MVP、MVVM模式的概念与区别
1. MVC框架 MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用一种业务逻辑.数据.界面显示 ...
- MVVM模式的几个开源框架
原文:MVVM模式的几个开源框架 实现MVVM的框架有很多,如: • MVVM Light Toolkit: http://mvvmlight.codeplex.com • Microsoft Pri ...
随机推荐
- Discrete.Differential.Geometry-An.Applied.Introduction(sig2008)笔记
-------------------------------------------------------------- Chapter 1: Introduction to Discrete D ...
- Hibernate之对象的三种状态
Hibernate之Java对象的三种状态 一.简述 本博文大部分的思想和内容引子CSND上名为 FG2006 这位大神的文章,连接地址为:http://blog.csdn.net/fg2006/ar ...
- 挖掘微信Web版通信的全过程 [转]
昨天是周末,在家闲得无聊,于是去weiphone.com逛了一圈,偶然发现有人发了一帖叫<微信 for Mac>, 这勾起了我的好奇心,国内做Mac开发的人确实很少,对于那些能够独自开发一 ...
- javascript bind
bind的作用和apply,call类似都是改变函数的execute context,也就是runtime时this关键字的指向.但是使用方法略有不同.一个函数进行bind后可稍后执行. 定义: fu ...
- BMP头文件格式以及C语言读取头文件【转】
BMP头文件格式以及C语言读取头文件[转] (2011-12-24 22:59:17) 转载▼ 标签: 杂谈 分类: 各个领域的知识 BMP图像文件由三部分组成:位图文件头数据结构,它包含BMP图像文 ...
- LinkedList
- 对话框AlertDialog.Builder使用方法
我们在平时做开发的时候,免不了会用到各种各样的对话框,相信有过其他平台开发经验的朋友都会知道,大部分的平台都只提供了几个最简单的实现,如果我们想实现自己特定需求的对话框,大家可能首先会想到,通过继承等 ...
- java 对EXCEL表格的处理
都整蒙圈了 Cannot get a numeric value from a text cell 的处理,EXCEL表格里是数值型的处理 http://blog.csdn.net/ysughw/ar ...
- Ionic发布成android
目前环境 1.ant的版本是1.9.4 2.jdk的版本是1.7 3.ionic安装版本是1.5.5 4.cordova版本是5.1.1 经测试,虽然ionic上面写的支持的最低版本是android- ...
- php-工厂模式(Factory Method)解析
关于工厂模式,首先要了解的就是多态这个概念:“多态是指在面向对象中能够根据使用类的上下文来重新定义或改变类的性质和行为”,这句话是我在其他博客看到,他已经概括的很好了,我就直接抄袭了.哈哈 通常简单工 ...