MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,用于组织代码用一种业务逻辑和数据显示分离的方法,这个方法的假设前提是如果业务逻辑被聚集到一个部件里面,而且界面和用户围绕数据的交互能被改进和个性化定制而不需要重新编写业务逻辑MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。
外文名: | MVC框架 |
全名: | Model View Controller |
产生时间: | 1982年 |
架构内容: | 视图,模型,控制器 |
类别: | 软件构件模式 |
简介
MVC开始是存在于 Desktop程序中的,M是指 数据模型,V是指 用户界面,C则是 控制器,使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据可以分别用 柱状图、 饼图来表示。 C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。 [1-2] 模型-视图-控制器( MVC)是 Xerox PARC在二十世纪八十年代为编程语言Smalltalk-80发明的一种 软件设计模式,已被广泛使用。后来被推荐为 Oracle旗下 Sun公司 Java EE平台的设计模式,并且受到越来越多的使用 ColdFusion 和 PHP 的开发者的欢迎。模型-视图-控制器模式是一个有用的 工具箱,它有很多好处,但也有一些缺点。 [3] (概述内容来源: [4] )编辑本段框架内容
MVC是一个框架模式,它强制性的使 应用程序的 输入、 处理和 输出分开。使用MVC应用程序被分成三个核心部件:模型、视图、控制器。它们各自处理自己的任务。 [5]视图
视图是用户看到并与之交互的界面。对老式的 Web应用程序来说,视图就是由 HTML元素组成的界面,在新式的Web应用程序中,HTML依旧在视图中扮演着重要的角色,但一些新的技术已层出不穷,它们包括 Adobe Flash和象XHTML,XML/XSL, WML等一些标识语言和 Web services. MVC好处是它能为应用程序处理很多不同的 视图。在视图中其实没有真正的处理发生,不管这些数据是联机存储的还是一个雇员列表,作为视图来讲,它只是作为一种输出数据并允许用户操纵的方式。 [6]模型
模型表示企业数据和业务规则。在MVC的三个部件中,模型拥有最多的处理任务。例如它可能用象EJBs和ColdFusion Components这样的构件 对象来处理数据库,被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据,由于应用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重复性。 [6]控制器
控制器接受用户的输入并调用模型和视图去完成用户的需求,所以当单击 Web页面中的超链接和发送 HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后再确定用哪个视图来显示返回的数据。 [6]编辑本段使用技巧
MVC框架的使用,主要在于Struts和Spring两个方面: Struts相关使用 Struts是 Apache软件基金下 Jakarta项目的一部分。Struts框架的主要架构设计和开发者是Craig R.McClanahan。Struts 是Java Web MVC框架中不争的王者。经过长达五年的发展,Struts已经逐渐成长为一个稳定、成熟的框架,并且占有了MVC框架中最大的市场份额。但是Struts某些技术特性上已经落后于新兴的MVC框架。面对 Spring MVC、Webwork2 这些设计更精密,扩展性更强的框架,Struts受到了前所未有的挑战。但站在产品开发的角度而言,Struts仍然是最稳妥的选择。 Struts有一组相互协作的类(组件)、Serlvet以及jsp tag lib组成。基于struts构架的web应用程序基本上符合JSP Model2的设计标准,可以说是MVC设计模式的一种变化类型。根据上面对framework的描述,很容易理解为什么说Struts是一个web framwork,而不仅仅是一些标记库的组合。但 Struts 也包含了丰富的标记库和独立于该框架工作的实用程序类。Struts有其自己的控制器(Controller),同时整合了其他的一些技术去实现模型层( Model)和视图层( View)。在模型层,Struts可以很容易的与数据访问技术相结合,包括EJB,JDBC和Object Relation Bridge。在视图层,Struts能够与JSP, Velocity Templates,XSL等等这些表示层组件相结合。 [7] Spring相关使用 Spring 实际上是Expert One-on-One J2EE Design and Development 一书中所阐述的设计思想的具体实现。在One-on-One 一书中, Rod Johnson 倡导 J2EE实用主义的设计思想,并随书提供了一个初步的开发框架实现(interface21 开发包)。而Spring 正是这一思想的更全面和具体的体现。Rod Johnson 在interface21 开发包的基础之上,进行了进一步的改造和扩充,使其发展为一个更加开放、清晰、全面、高效的开发框架。 Spring是一个开源框架,由Rod Johnson创建并且在他的著作《J2EE设计开发编程指南》里进行了描述。它是为了解决企业应用开发的复杂性而创建的。Spring使使用基本的JavaBeans来完成以前只可能由EJB完成的事情变得可能了。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。 简单来说,Spring是一个轻量的控制反转和面向切面的容器框架。当然,这个描述有点过于简单。但它的确概括出了Spring是做什么的。 [7] (MVC框架的详细使用及其相关具体操作可以阅读参考资料: [7] 或者扩展阅读第二,三,四条。)编辑本段优缺点
优点
耦合性低 视图层和业务层分离,这样就允许更改视图层代码而不用重新编译模型和控制器代码,同样,一个应用的业务流程或者业务规则的改变只需要改动MVC的模型层即可。因为模型与控制器和视图相分离,所以很容易改变应用程序的数据层和业务规则。 模型是自包含的,并且与控制器和视图相分离,所以很容易改变应用程序的数据层和业务规则。如果把数据库从 MySQL移植到 Oracle,或者改变基于RDBMS数据源到 LDAP,只需改变模型即可。一旦正确的实现了模型,不管数据来自数据库或是LDAP服务器,视图将会正确的显示它们。由于运用MVC的应用程序的三个部件是相互独立,改变其中一个不会影响其它两个,所以依据这种设计思想能构造良好的 松耦合的构件。 [8] 重用性高 随着技术的不断进步,需要用越来越多的方式来访问应用程序。 MVC模式允许使用各种不同样式的视图来访问同一个服务器端的代码,因为多个视图能共享一个模型,它包括任何WEB(HTTP) 浏览器或者无线浏览器(wap),比如,用户可以通过电脑也可通过手机来订购某样产品,虽然订购的方式不一样,但处理订购产品的方式是一样的。由于模型返回的数据没有进行格式化,所以同样的构件能被不同的界面使用。例如,很多数据可能用HTML来表示,但是也有可能用WAP来表示,而这些表示所需要的命令是改变视图层的实现方式,而控制层和模型层无需做任何改变。由于已经将数据和业务规则从表示层分开,所以可以最大化的重用代码了。模型也有状态管理和数据持久性处理的功能,例如,基于会话的购物车和电子商务过程也能被Flash网站或者无线联网的应用程序所重用。 [8] 生命周期成本低 MVC使开发和维护用户接口的技术含量降低。 部署快 使用MVC模式使开发时间得到相当大的缩减,它使程序员(Java开发人员)集中精力于业务逻辑,界面程序员(HTML和JSP 开发人员)集中精力于表现形式上。 可维护性高 分离视图层和业务逻辑层也使得WEB应用更易于维护和修改。 有利软件工程化管理 由于不同的层各司其职,每一层不同的应用具有某些相同的特征,有利于通过工程化、工具化管理程序代码。控制器也提供了一个好处,就是可以使用控制器来联接不同的模型和视图去完成用户的需求,这样控制器可以为构造应用程序提供强有力的手段。给定一些可重用的模型和视图,控制器可以根据用户的需求选择模型进行处理,然后选择视图将处理结果显示给用户。 [9-10]缺点
没有明确的定义 完全理解MVC并不是很容易。使用MVC需要精心的计划,由于它的内部原理比较复杂,所以需要花费一些时间去思考。同时由于模型和视图要严格的分离,这样也给调试应用程序带来了一定的困难。每个构件在使用之前都需要经过彻底的测试。 不适合小型,中等规模的应用程序 花费大量时间将MVC应用到规模并不是很大的应用程序通常会得不偿失。 增加系统结构和实现的复杂性 对于简单的界面,严格遵循MVC,使模型、视图与控制器分离,会增加结构的复杂性,并可能产生过多的更新操作,降低运行效率。 视图与控制器间的过于紧密的连接 视图与控制器是相互分离,但却是联系紧密的部件,视图没有控制器的存在,其应用是很有限的,反之亦然,这样就妨碍了他们的独立重用。 视图对模型数据的低效率访问 依据模型操作接口的不同,视图可能需要多次调用才能获得足够的显示数据。对未变化数据的不必要的频繁访问,也将损害操作性能。 一般高级的界面工具或构造器不支持模式 改造这些工具以适应MVC需要和建立分离的部件的代价是很高的,会造成MVC使用的困难。 [9-10]编辑本段外界评价
根据天极网资料显示:基于Web的MVC framework在J2EE的世界内已是空前繁荣, TTS网站上几乎每隔一两个星期就会有新的MVC框架发布,比较好的MVC,老牌的有Struts、Webwork。新兴的MVC 框架有Spring MVC、Tapestry、JSF等。这些大多是著名团队的作品,另外还有一些边缘团队的作品,也相当出色,如Dinamica、 VRaptor等,这些框架都提供了较好的层次分隔能力,在实现良好的MVC 分隔的基础上,通过提供一些现成的辅助类库,同时也促进了生产效率的提高。 [7] 如何选择一个好的框架应用在项目中,将会对项目的效率和可重用是至关重要的。 [7]-
参考资料
-
-
1. Asp.net MVC2.0系列文章-MVC简介篇 .cn博客 [引用日期2012-12-13] .
-
2. 1.3 理解MVC(Model-View-Controller)模式-视图-控制器 .book.cakephp网(外文网) [引用日期2012-12-13] .
-
3. MVC架构探究及其源码实现(1)-理论基础 .CSDN博客 [引用日期2012-12-13] .
-
4. ASP.NET MVC .CodePlex网(外文网) [引用日期2012-12-13] .
-
5. 细说MVC框架的几大困惑 .51com网 [引用日期2012-12-13] .
-
6. Joomla MVC 组件开发 (1) .dongxi网 [引用日期2012-12-13] .
-
7. Struts VS Spring 两种MVC框架比较 .天极网 [引用日期2012-12-17] .
-
8. 基于中间件技术的制造执行系统架构设计与实现 .智造网 [引用日期2012-12-13] .
-
9. mvc原理和mvc模式的优缺点 .ITeye网博客 [引用日期2012-12-13] .
-
10. 11.2 为什么要使用 MVC .51cto网 [引用日期2012-12-13] .
-
-
扩展阅读:
-
- 1
框架不是框框—应用框架的基本思想:http://java.chinaitlab.com/model/722785.html
- 2
Spring MVC 框架搭建及详解:http://www.open-open.com/lib/view/open1338338587698.html
- 3
struts2 mvc框架搭建及详解:http://struts2.group.iteye.com/group/wiki/1390-confusion-with-mvc-framework
- 4
.NET MVC框架知识详细讲解:http://www.zxbc.cn/a/aspnet/20100701113016.html
- 1