浅谈mvc,mvp,mvvm的理解(一)

时间:2022-12-21 21:15:43

关于mvc,mvp和mvvm做程序员大家应该都听说过,就是没听说过后面两个,哪mvc也应该都知道,一开始骨灰级的程序员都应该最早接触的是mvc模式,这种模式流行数年,之所以后来会出现mvp和mvvm这两种模式,就是在伴随做项目业务量不断的增加以及需求不断的变更,发现mvc已经无法满足,为了解决mvc出现的弊端,mvp模式就应允而生,同理mvvm也是逐步推出,也就是现在我们经常挂在嘴边的后两种模式,也是前任不好意思打错啦,也是前人在开发实践中总结出来。再次作为一个后来者我们应该向前辈致敬。好了废话不多说,回归正题。

 1.首先我们先对mvcmvpmvvm概念分别做下理解

 mvc模式

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

浅谈mvc,mvp,mvvm的理解(一)

Model(模型)是应用程序中用于处理应用程序数据逻辑的部分。

  通常模型对象负责在数据库中存取数据(在java中也具体指对象model)。

View(视图)是应用程序中处理数据显示的部分。

  通常视图是依据模型数据创建的。

Controller(控制器)是应用程序中处理用户交互的部分。

  通常控制器负责从视图读取数据,控制用户输入,并向模型发送数据。

MVC 分层有助于管理复杂的应用程序,因为您可以在一个时间内专门关注一个方面。例如,您可以在不依赖业务逻辑的情况下专注于视图设计。同时也让应用程序的测试更加容易。

 

mvc缺点:

1、增加了系统结构和实现的复杂性。对于简单的界面,严格遵循MVC,使模型、视图与控制器分离,会增加结构的复杂性,并可能产生过多的更新操作,降低运行效率。

2、视图与控制器间的过于紧密的连接。视图与控制器是相互分离,但确实联系紧密的部件,视图没有控制器的存在,其应用是很有限的,反之亦然,这样就妨碍了他们的独立重用。

3、视图对模型数据的低效率访问。依据模型操作接口的不同,视图可能需要多次调用才能获得足够的显示数据。对未变化数据的不必要的频繁访问,也将损害操作性能。

4、目前,一般高级的界面工具或构造器不支持模式。改造这些工具以适应MVC需要和建立分离的部件的代价是很高的,从而造成MVC使用的困难

     

mvp模式

mvp模式主要是解决mvc中的缺点,mvp作为一种新的模式,MVP与MVC有着一个重大的区别:在MVP中View并不直接使用Model,它们之间的通信是通过Presenter (MVC中的Controller)来进行的,所有的交互都发生在Presenter内部,而在MVC中View会直接从Model中读取数据而不是通过 Controller。

 浅谈mvc,mvp,mvvm的理解(一)

MVP的优点编辑

1、模型与视图完全分离,我们可以修改视图而不影响模型

2、可以更高效地使用模型,因为所有的交互都发生在一个地方——Presenter内部

3、我们可以将一个Presenter用于多个视图,而不需要改变Presenter的逻辑。这个特性非常的有用,因为视图的变化总是比模型的变化频繁。

4、如果我们把逻辑放在Presenter中,那么我们就可以脱离用户接口来测试这些逻辑(单元测试)

 

mvvm模式

MVVM(Model-View-ViewModel)

 

如果说MVP是对MVC的进一步改进,那么MVVM则是思想的完全变革。它是将“数据模型数据双向绑定”的思想作为核心,因此在View和Model之间没有联系,通过ViewModel进行交互,而且Model和ViewModel之间的交互是双向的,因此视图的数据的变化会同时修改数据源,而数据源数据的变化也会立即反应到View上。

 浅谈mvc,mvp,mvvm的理解(一)

这方面典型的应用有.NET的WPF,js框架Knockout、AngularJS等。

 

 

本片文章先对mvc和mvp以及mvvm概念做个理解。具体的使用会在后面博客中详细讲解,有不对的地方欢迎拍砖。