MVC框架

生活百科 2023-01-17 20:00生活百科www.aizhengw.cn

MVC框架

mvc一般指本词条

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

基本介绍

  • 中文名MVC
  • 外文名MVC框架
  • 全名Model View Controller
  • 产生时间1982年
  • 架构内容视图,模型,控制器
  • 类别软体构件模式

简介

MVC开始是存在于桌面程式中的,M是指业务模型,V是指用户界面,C则是控制器,使用MVC的目的是将M和V的实现代码分离,从而使同一个程式可以使用不同的表现形式。比如一批统计数据可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。
模型-视图-控制器(MVC)是Xerox PARC在二十世纪八十年代为程式语言Smalltalk-80发明的一种软体设计模式,已被广泛使用。后来被推荐为Oracle旗下Sun公司Java EE平台的设计模式,并且受到越来越多的使用ColdFusion和PHP的开发者的欢迎。模型-视图-控制器模式是一个有用的工具箱,它有很多好处,但也有一些缺点。
(概述内容来源)

MVC 编程模式

MVC 是一种使用 MVC(Model View Controller 模型-视图-控制器)设计创建 Web 应用程式的模式
  • Model(模型)表示应用程式核心(比如资料库记录列表)。
  • View(视图)显示数据(资料库记录)。
  • Controller(控制器)处理输入(写入资料库记录)。
MVC 模式提供了对 HTML、CSS 和 JavaScript 的完全控制。
Model(模型)是应用程式中用于处理应用程式数据逻辑的部分。
通常模型对象负责在资料库中存取数据。
View(视图)是应用程式中处理数据显示的部分。
通常视图是依据模型数据创建的。
Controller(控制器)是应用程式中处理用户互动的部分。
通常控制器负责从视图读取数据,控制用户输入,并向模型传送数据。
MVC 分层有助于管理複杂的应用程式,因为您可以在一个时间内专门关注一个方面。例如,您可以在不依赖业务逻辑的情况下专注于视图设计。也让应用程式的测试更加容易。
MVC 分层也简化了分组开发。不同的开发人员可开发视图、控制器逻辑和业务逻辑。

框架内容

MVC指MVC模式的某种框架,它强制性的使应用程式的输入、处理和输出分开。使用MVC应用程式被分成三个核心部件模型、视图、控制器。它们各自处理自己的任务。最典型的MVC就是JSP + servlet + javabean的模式。

视图

视图是用户看到并与之互动的界面。对老式的Web应用程式来说,视图就是由HTML元素组成的界面,在新式的Web应用程式中,HTML依旧在视图中扮演着重要的角色,但一些新的技术已层出不穷,它们包括Adobe Flash和像XHTML,XML/XSL,WML等一些标识语言和Web services.
MVC好处是它能为应用程式处理很多不同的视图。在视图中其实没有真正的处理髮生,不管这些数据是在线上存储的还是一个雇员列表,作为视图来讲,它只是作为一种输出数据并允许用户操纵的方式。

模型

模型表示企业数据和业务规则。在MVC的三个部件中,模型拥有最多的处理任务。例如它可能用像EJBs和ColdFusion Components这样的构件对象来处理资料库,被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据,由于套用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重複性。

控制器

控制器接受用户的输入并调用模型和视图去完成用户的需求,所以当单击Web页面中的超连结和传送HTML表单时,控制器本身不输出任何东西和做任何处理。它只是接收请求并决定调用哪个模型构件去处理请求,然后再确定用哪个视图来显示返回的数据。

区别

框架和设计模式的区别
有很多程式设计师往往把框架模式和设计模式混淆,认为MVC是一种设计模式。实际上它们完全是不同的概念。
框架、设计模式这两个概念总容易被混淆,其实它们之间还是有区别的。框架通常是代码重用,而设计模式是设计重用,架构则介于两者之间,部分代码重用,部分设计重用,有时分析也可重用。在软体生产中有三种级别的重用内部重用,即在同一套用中能公共使用的抽象块;代码重用,即将通用模组组合成库或工具集,以便在多个套用和领域都能使用;套用框架的重用,即为专用领域提供通用的或现成的基础结构,以获得最高级别的重用性。
框架与设计模式虽然相似,但却有着根本的不同。设计模式是对在某种环境中反覆出现的问题以及解决该问题的方案的描述,它比框架更抽象;框架可以用代码表示,也能直接执行或复用,而对模式而言只有实例才能用代码表示;设计模式是比框架更小的元素,一个框架中往往含有一个或多个设计模式,框架总是针对某一特定套用领域,但同一模式却可适用于各种套用。可以说,框架是软体,而设计模式是软体的知识。
框架模式有哪些?
MVC、MTV、MVP、CBD、ORM等等;
框架有哪些?
C++语言的QT、MFC、gtk,Java语言的SSH 、SSI,php语言的 smarty(MVC模式),python语言的django(MTV模式)等等
设计模式有哪些?
工厂模式、适配器模式、策略模式等等
简而言之框架是大智慧,用来对软体设计进行分工;设计模式是小技巧,对具体问题提出解决方案,以提高代码复用率,降低耦合度。

常见框架

Struts

Struts是Apache软体基金下Jakarta项目的一部分。Struts框架的主要架构设计和开发者是Craig R.McClanahan。Struts 是Java Web MVC框架中不争的王者。经过长达九年的发展,Struts已经逐渐成长为一个稳定、成熟的框架,并且占有了MVC框架中最大的市场份额。Struts某些技术特性上已经落后于新兴的MVC框架。面对Spring MVC、Webwork2这些设计更精密,扩展性更强的框架,Struts受到了前所未有的挑战。但站在产品开发的角度而言,Struts仍然是最稳妥的选择。
Struts有一组相互协作的类(组件)、Servlet以及jsp tag lib组成。基于struts构架的web应用程式基本上符合JSP Model2的设计标準,可以说是MVC设计模式的一种变化类型。根据上面对framework的描述,很容易理解为什幺说Struts是一个web framework,而不仅仅是一些标记库的组合。但 Struts 也包含了丰富的标记库和独立于该框架工作的实用程式类。Struts有其自己的控制器(Controller),整合了其他的一些技术去实现模型层(Model)和视图层(View)。在模型层,Struts可以很容易的与数据访问技术相结合,包括EJB,JDBC和Object Relation Bridge。在视图层,Struts能够与JSP, Velocity Templates,XSL等等这些表示层组件相结合。

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是做什幺的。

ZF

Zend Framework(简写ZF)是由 Zend 公司支持开发的完全基于 PHP5 的开源PHP开发框架,可用于开发 Web 程式和服务,ZF採用 MVC(Model–View-Controller) 架构模式来分离应用程式中不同的部分方便程式的开发和维护。
(MVC框架的详细使用及其相关具体操作可以阅读参考资料或者扩展阅读第二,三,四条。)

.NET

.NET MVC是微软官方提供的以MVC模式为基础的.NET Web应用程式(Web Application)框架,它由Castle的MonoRail而来(Castle的MonoRail是由java而来),目前最新版本是.N 4.5。

特点

优点

耦合性
视图层和业务层分离,这样就允许更改视图层代码而不用重新编译模型和控制器代码,同样,一个套用的业务流程或者业务规则的改变只需要改动MVC的模型层即可。因为模型与控制器和视图相分离,所以很容易改变应用程式的数据层和业务规则。
模型是自包含的,并且与控制器和视图相分离,所以很容易改变应用程式的数据层和业务规则。如果把资料库从MySQL移植到Oracle,或者改变基于RDBMS数据源到LDAP,只需改变模型即可。一旦正确的实现了模型,不管数据来自资料库或是LDAP伺服器,视图将会正确的显示它们。由于运用MVC的应用程式的三个部件是相互独立,改变其中一个不会影响其它两个,所以依据这种设计思想能构造良好的松耦合的构件。
重用性高
随着技术的不断进步,需要用越来越多的方式来访问应用程式。MVC模式允许使用各种不同样式的视图来访问同一个伺服器端的代码,因为多个视图能共享一个模型,它包括任何WEB(HTTP)浏览器或者无线浏览器(wap),比如,用户可以通过电脑也可通过手机来订购某样产品,虽然订购的方式不一样,但处理订购产品的方式是一样的。由于模型返回的数据没有进行格式化,所以同样的构件能被不同的界面使用。例如,很多数据可能用HTML来表示,也有可能用WAP来表示,而这些表示所需要的命令是改变视图层的实现方式,而控制层和模型层无需做任何改变。由于已经将数据和业务规则从表示层分开,所以可以最大化的重用代码了。模型也有状态管理和数据持久性处理的功能,例如,基于会话的购物车和电子商务过程也能被Flash网站或者无线联网的应用程式所重用。
生命周期成本低
MVC使开发和维护用户接口的技术含量降低。
部署快
使用MVC模式使开发时间得到相当大的缩减,它使程式设计师(Java开发人员)集中精力于业务逻辑,界面程式设计师(HTML和JSP开发人员)集中精力于表现形式上。
可维护性高
分离视图层和业务逻辑层也使得WEB套用更易于维护和修改。
有利软体工程化管理
由于不同的层各司其职,每一层不同的套用具有某些相同的特徵,有利于通过工程化、工具化管理程式代码。控制器也提供了一个好处,就是可以使用控制器来联接不同的模型和视图去完成用户的需求,这样控制器可以为构造应用程式提供强有力的手段。给定一些可重用的模型和视图,控制器可以根据用户的需求选择模型进行处理,然后选择视图将处理结果显示给用户。

缺点

没有明确的定义
完全理解MVC并不是很容易。使用MVC需要精心的计画,由于它的内部原理比较複杂,所以需要花费一些时间去思考。由于模型和视图要严格的分离,这样也给调试应用程式带来了一定的困难。每个构件在使用之前都需要经过彻底的测试。
不适合小型,中等规模的应用程式
花费大量时间将MVC套用到规模并不是很大的应用程式通常会得不偿失。
增加系统结构和实现的複杂性
对于简单的界面,严格遵循MVC,使模型、视图与控制器分离,会增加结构的複杂性,并可能产生过多的更新操作,降低运行效率。
视图与控制器间的过于紧密的连线
视图与控制器是相互分离,但却是联繫紧密的部件,视图没有控制器的存在,其套用是很有限的,反之亦然,这样就妨碍了他们的独立重用。
视图对模型数据的低效率访问
依据模型操作接口的不同,视图可能需要多次调用才能获得足够的显示数据。对未变化数据的不必要的频繁访问,也将损害操作性能。
一般高级的界面工具或构造器不支持模式
改造这些工具以适应MVC需要和建立分离的部件的代价是很高的,会造成MVC使用的困难。

外界评价

根据天极网资料显示基于Web的MVC framework在J2EE的世界内已是空前繁荣,TTS网站上几乎每隔一两个星期就会有新的MVC框架发布,比较好的MVC,老牌的有Struts、Webwork。新兴的MVC 框架有Spring MVC、Tapestry、JSF等。这些大多是着名团队的作品,还有一些边缘团队的作品,也相当出色,如Dinamica、VRaptor等,这些框架都提供了较好的层次分隔能力,在实现良好的MVC 分隔的基础上,通过提供一些现成的辅助类库,也促进了生产效率的提高。
如何选择一个好的框架套用在项目中,将会对项目的效率和可重用是至关重要的。

MVC控制项

在ASP .NET MVC框架中没有了自己的控制项,页面显示完全就回到了写html代码的年代。还好在 asp .net mvc框架中也有自带的HtmlHelper和UrlHelper两个帮助类。在MvcContrib扩展项目中也有扩展一些帮助类,这样我们就不光只能使用完整的html来编写了需要显示的页面了,就可以使用这些帮助类来完成,但运行时都还是要生成html代码的。
HtmlHelper类
HtmlHelper类位于System.Web.MVC.Html命名空间下。主要包括FormExtensions,InputExtensions,
LinkExtensions,SelectExtensions,TextAreaExtensions,ValidationExtensions,RenderPartialExtensions等7个静态类,他们全部是是採用拓展方法来实现的。
InputExtensions类主要有5种类型的扩展方法,分别用于CheckBox控制项、Hidden控制项、Pass控制项、RadionButton控制项和TextBox控制项
LinkExtensions类该类主要用于生成相关连结,主要扩展了ActionLink和RouteLink方法。
ActionLink扩展方法主要实现一个连线,共有十个重载方法。
UrlHelper帮助类
看类名也都知道这个类是用来成URL在 ASP .NET MVC应用程式中。
UrlHelper提供了四个非常常用的四个方法。
1.Action方法通过提供Controller,Action和各种参数生成一个URL,
2.Content方法是将一个虚拟的,相对的路径转换到应用程式的绝对路径,
3.Encode方法是对URL地址进行加密,与Server.Encode方法一样。
4.RouteUrl方法是提供在当前应用程式中规定的路由规则中匹配出URL。
还有两个属性,分别是RequestContext和RouteCollection两个属性,分别指的是包含HTTP上下文和RouteData两个属性,,RouteCollection是整个当前应用程式中规定的路由规则。
自定义控制项
微软提供的HtmlHelper已经是足够大部分开发人员使用了,有一些功能要用微软提供的HtmlHelper可能还不满足要求。接下来就谈谈如何自定义的过程。
自定义的方法就是对HtmlHelper对象的扩展。
扩展方法实现的三要素1、静态类 2、静态方法 3、this关键字
1、先定义一个类,例如MyHtmlHelper
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace MvcApplicationFirstDome.Models {
//静态类
public static class MyHtmlHelper
{
//静态方法
}
}
2、假设要扩展的方式是GetSpan,作用就是当你传入参数时,内部封装了之后返回结果,代码如下。注意在MyHtmlHelper类中要引用using System.Web.Mvc命名空间。
//静态方法
public static string GetSpan(this HtmlHelper htmlHelper,string text)
{
return "<span style='color:Red'>"+text+"</span>";
}
经过上面两步之后HtmlHelper的扩展方法GetSpan基本可以使用了,接下来就讲解如何在页面调用了。
在调用的时候要注意下一命名空间如果扩展方法的命名空间和页面的命名空间不同的就必须引用扩展方法的命名空间,否则在页面是没有办法调用自定义的方法的。
引用完命名空间之后,就可以在相应的页面调用自定义的扩展方法了。
对于某些项目来说,自定义控制项过于複杂和浪费时间。这个时候也可以从技术社区或是原始码站下载适合自己需求的Mvc控制项。如一些控制项套包,表格控制项等。
上一篇:kindle电子书阅读器 下一篇:Kevin Cannon

Copyright@2015-2025 www.aizhengw.cn 癌症网版板所有