什么是MVC框架.docx

上传人:b****5 文档编号:12193029 上传时间:2023-04-17 格式:DOCX 页数:14 大小:130.93KB
下载 相关 举报
什么是MVC框架.docx_第1页
第1页 / 共14页
什么是MVC框架.docx_第2页
第2页 / 共14页
什么是MVC框架.docx_第3页
第3页 / 共14页
什么是MVC框架.docx_第4页
第4页 / 共14页
什么是MVC框架.docx_第5页
第5页 / 共14页
点击查看更多>>
下载资源
资源描述

什么是MVC框架.docx

《什么是MVC框架.docx》由会员分享,可在线阅读,更多相关《什么是MVC框架.docx(14页珍藏版)》请在冰豆网上搜索。

什么是MVC框架.docx

什么是MVC框架

什么是MVC框架

MVC(ModalViewControler)本来是存在于Desktop程序中的,M是指数据模型,V是指用户界面,C则是控制器。

使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。

比如一批统计数据你可以分别用柱状图、饼图来表示。

C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。

模型-视图-控制器(MVC)是XeroxPARC在八十年代为编程语言Smalltalk-80发明的一种软件设计模式,至今已被广泛使用。

最近几年被推荐为Sun公司J2EE平台的设计模式,并且受到越来越多的使用ColdFusion和PHP的开发者的欢迎。

模型-视图-控制器模式是一个有用的工具箱,它有很多好处,但也有一些缺点。

MVC如何工作

MVC是一个设计模式,它强制性的使应用程序的输入、处理和输出分开。

使用MVC应用程序被分成三个核心部件:

模型、视图、控制器。

它们各自处理自己的任务。

视图

视图是用户看到并与之交互的界面。

对老式的Web应用程序来说,视图就是由HTML元素组成的界面,在新式的Web应用程序中,HTML依旧在视图中扮演着重要的角色,但一些新的技术已层出不穷,它们包括MacromediaFlash和象XHTML,XML/XSL,WML等一些标识语言和Webservices.

如何处理应用程序的界面变得越来越有挑战性。

MVC一个大的好处是它能为你的应用程序处理很多不同的视图。

在视图中其实没有真正的处理发生,不管这些数据是联机存储的还是一个雇员列表,作为视图来讲,它只是作为一种输出数据并允许用户操纵的方式。

模型

模型表示企业数据和业务规则。

在MVC的三个部件中,模型拥有最多的处理任务。

例如它可能用象EJBs和ColdFusionComponents这样的构件对象来处理数据库。

被模型返回的数据是中立的,就是说模型与数据格式无关,这样一个模型能为多个视图提供数据。

由于应用于模型的代码只需写一次就可以被多个视图重用,所以减少了代码的重复性。

控制器

控制器接受用户的输入并调用模型和视图去完成用户的需求。

所以当单击Web页面中的超链接和发送HTML表单时,控制器本身不输出任何东西和做任何处理。

它只是接收请求并决定调用哪个模型构件去处理请求,然后用确定用哪个视图来显示模型处理返回的数据。

现在我们总结MVC的处理过程,首先控制器接收用户的请求,并决定应该调用哪个模型来进行处理,然后模型用业务逻辑来处理用户的请求并返回数据,最后控制器用相应的视图格式化模型返回的数据,并通过表示层呈现给用户。

为什么要使用MVC

大部分Web应用程序都是用像ASP,PHP,或者CFML这样的过程化语言来创建的。

它们将像数据库查询语句这样的数据层代码和像HTML这样的表示层代码混在一起。

经验比较丰富的开发者会将数据从表示层分离开来,但这通常不是很容易做到的,它需要精心的计划和不断的尝试。

MVC从根本上强制性的将它们分开。

尽管构造MVC应用程序需要一些额外的工作,但是它给我们带来的好处是无庸质疑的。

首先,最重要的一点是多个视图能共享一个模型,正如我所提及的,现在需要用越来越多的方式来访问你的应用程序。

对此,其中一个解决之道是使用MVC,无论你的用户想要Flash界面或是WAP界面;用一个模型就能处理它们。

由于你已经将数据和业务规则从表示层分开,所以你可以最大化的重用你的代码了。

由于模型返回的数据没有进行格式化,所以同样的构件能被不同界面使用。

例如,很多数据可能用HTML来表示,但是它们也有可能要用MacromediaFlash和WAP来表示。

模型也有状态管理和数据持久性处理的功能,例如,基于会话的购物车和电子商务过程也能被Flash网站或者无线联网的应用程序所重用。

因为模型是自包含的,并且与控制器和视图相分离,所以很容易改变你的应用程序的数据层和业务规则。

如果你想把你的数据库从MySQL移植到Oracle,或者改变你的基于RDBMS数据源到LDAP,只需改变你的模型即可。

一旦你正确的实现了模型,不管你的数据来自数据库或是LDAP服务器,视图将会正确的显示它们。

由于运用MVC的应用程序的三个部件是相互对立,改变其中一个不会影响其它两个,所以依据这种设计思想你能构造良好的松偶合的构件。

对我来说,控制器的也提供了一个好处,就是可以使用控制器来联接不同的模型和视图去完成用户的需求,这样控制器可以为构造应用程序提供强有力的手段。

给定一些可重用的模型和视图,控制器可以根据用户的需求选择模型进行处理,然后选择视图将处理结果显示给用户。

MVC的缺点

MVC的缺点是由于它没有明确的定义,所以完全理解MVC并不是很容易。

使用MVC需要精心的计划,由于它的内部原理比较复杂,所以需要花费一些时间去思考。

你将不得不花费相当可观的时间去考虑如何将MVC运用到你的应用程序,同时由于模型和视图要严格的分离,这样也给调试应用程序到来了一定的困难。

每个构件在使用之前都需要经过彻底的测试。

一旦你的构件经过了测试,你就可以毫无顾忌的重用它们了。

根据我个人经验,由于我们将一个应用程序分成了三个部件,所以使用MVC同时也意味着你将要管理比以前更多的文件,这一点是显而易见的。

这样好像我们的工作量增加了,但是请记住这比起它所能带给我们的好处是不值一提。

MVC并不适合小型甚至中等规模的应用程序,花费大量时间将MVC应用到规模并不是很大的应用程序通常会得不偿失。

MVC是一条创建软件的好途径

MVC设计模式是一个很好创建软件的途径,它所提倡的一些原则,像内容和显示互相分离可能比较好理解。

但是如果你要隔离模型、视图和控制器的构件,你可能需要重新思考你的应用程序,尤其是应用程序的构架方面。

如果你肯接受MVC,并且有能力应付它所带来的额外的工作和复杂性,MVC将会使你的软件在健壮性,代码重用和结构方面上一个新的台阶。

参考资料:

m-model就是数据实体,用来存放数据的

v-view对用户的界面

c-control控制业务逻辑的部分

和MVC结构相关的是观察者(Observer)的设计模式,即所有的View是Model的观察者,只要Model发生变化,它就要通知它的观察者以更新所有的观察者。

我们比较熟悉的MFC中的文档-视图结构就可以理解为MVC的结构,在这里文档就是Model,它保存真正的数据,视图就是View,它以自己的方式显示文档中的数据,而消息则可以认为是Control。

.NET Web开发震撼之变:

.NET MVC框架

MVC概念

   MVC是一种架构设计模式,该模式主要应用于图形化用户界面(GUI)应用程序。

那么什么是MVC?

MVC由三部分组成:

Model(模型)、View(视图)及Controller(控制器)。

   Model即应用程序的数据模型。

任何应用程序都离不开数据,数据可以存储在数据库中、磁盘文件中,甚至内存中。

Model就是对这些数据的抽象,不论数据采取何种存储形式,应用程序总是能够通过Model来对数据进行操作,而不必关心数据的存储形式。

数据实体类就是常用的一种Model。

例如,一个客户管理应用程序使用数据库来存储客户数据,数据库表中有一个客户表Customer,相应的程序中一般会建立一个数据实体类Customer来与之对应,这个实体类即使客户表的Model。

   View是应用程序的界面。

用户通过View来操作应用程序,完成与程序的交互。

View提供了可视化的界面来显示Model中定义的数据,用户通过View来操作数据,并将对Model数据操作的结果返回给用户。

在桌面应用程序中,View可能是一个或多个Windows窗体。

在Web应用程序中,View是由一系列网页构成,在ASP.NET网站中即为.aspx页面。

   Controller定义了程序的应用逻辑。

用户通过View发送操作命令给Controller,由Controller按照程序设计的逻辑来更新Model定义的数据,并将操作结果通过View返回给用户。

  

   MVC的历史

   MVC这一概念最早由美国教授TrygveReenskaug于1979年提出。

1988年MVC这一设计模式正式在《ACookbookforUsingtheModel-View-ControllerUserInterfaceParadigminSmalltalk-80》一书中提出。

伴随着微软Windows操作系统的迅速发展与普及,图形化用户界面应用程序逐渐成为主流,很多编程语言都出现了MVC框架,以方便开发人员使用该模式来设计应用程序。

这些框架中大部分都是针对Web应用程序。

   .NETWeb开发中MVC设计模式的实现

   ASP.NET1.x中使用了CodeBehind技术,彻底终结了传统ASP程序开发的梦魇:

程序逻辑与HTML界面元素混杂在一起。

CodeBehind技术将代表程序界面(View)的.aspx文件与逻辑(Controller)代码.vb/.cs文件的分离即是一种MVC式的设计。

ASP.NET2.0中又出现了CodeBeside技术,即一个.aspx文件可以有多个.vb/.cs文件,这又方便了界面与逻辑代码的进一步分离。

   2008年3月微软发布了针对ASP.NET3.5的MVC框架(Preview2版本)。

这是一个真正意义上的ASP.NETMVC框架。

该框架可以说是对之前为开发人员所熟悉的基于WebForm的应用程序开发方式的"颠覆"。

变化可谓"震撼":

   1. 使用URLRouting技术:

Web程序的URL不再是指向具体的物理页面.aspx,而是指向某个Controller的某个方法。

一个典型的MVC架构的程序,其URL可能如下所示:

   

   使用该MVC架构的程序其URL不必有文件扩展名。

上面这个URL中的Customer即为Controller的名字。

而Index是Customer定义的一个方法名。

   2. Web程序的界面.aspx不再使用服务器端的Form:

   

formrunat="server">

   那么与服务器端的Form相关的Postback以及页面生命周期的事件也不存在了。

   3. 页面中不再有ViewState。

MVC下将不能使用ViewState来存储程序状态信息。

   4. 不再提供依赖于服务器端Form的服务器控件事件,开发人员熟悉的Button_Clicked事件在MVC下将不再需要。

    

   NETMVC示例

   安装完ASP.NETMVCPreview2后,VS2008中会添加一个新的项目模板"ASP.NETMVCWebApplication",如下图所示

    

    

   新建该项目后,VS2008自动生成项目的文件结构如下,MVC三个组成部分各有一个文件夹来存储各自的程序文件。

    

   

    

   前面提到的URLRouting即在Global.asax.cs中设置:

    

    

 

publicclassGlobalApplication:

System.Web.HttpApplication

   {

       publicstaticvoidRegisterRoutes(RouteCollectionroutes)

       {

           //注意:

IIS7以下的IIS版本需将URL格式设置为"{controller}.mvc/{action}/{id}"toenable           

           routes.Add(newRoute("{controller}.mvc/{action}/{id}",newMvcRouteHandler())

           {

               Defaults=newRouteValueDictionary(new{action="Index",id=""}),

           });//设置URLRouting格式

           routes.Add(newRoute("Default.aspx",newMvcRouteHandler())

           {

               Defaults=newRouteValueDictionary(new{controller="Customer",action="Index",id=""}),

           });//设置默认URL指向CustomerController的Index方法

       }

       protectedvoidApplication_Start(objectsender,EventArgse)

       {

           RegisterRoutes(RouteTable.Routes);

       }

}

    

   【代码1】:

Global.asax.cs

   下面来实现Customer的Model、Controller及View:

   Model:

在项目中的Model文件夹下,新建一个"LinqtoSQLClasses",将Northwind数据库中的Customer表拖拽到其设计视图中。

这样就完成了Customer对应的Model。

如图4

  

   Controller:

在项目中的Controller文件夹下,新建一个"MVCControllerClass",命名为CustomerContoller.cs。

在此类中添加一个公有方法Index,此方法及为在Global.asax.cs中设置好的默认URL所映射的方法。

    

 

 publicclassCustomerController:

Controller

     {

       publicvoidIndex(stringid)

       {

           Northwind.Models.NorthwindDataContextdc=newNorthwind.Models.NorthwindDataContext();

           IListcustomers=dc.Customers.Take(10).ToList();//取数据库中的10个Customer记录

           RenderView("Index",customers);//返回IndexView

       }

}

    

   【代码2】:

CustomerController.cs

   View:

上面Index方法的代码表示CustomerContoller的Index方法执行后,需要返回一个名称为Index的View,以便将数据呈现给用户。

下面来添加这个IndexView:

在项目的View文件中,新建一个子文件夹Customer。

与CustomerController有关的View将保存在此文件夹下。

新建一个"MVCViewClass"并命名为Index.aspx。

在前面的RenderView("Index",customers)方法中,customers参数是Controller传递给View所需的数据,该参数的类型为IList

为了在View中方便使用此强类型的数据,View.aspx.cs使用了如下代码:

注意粗体部分

   

 

publicpartialclassIndex:

ViewPage>

   {

}

    

   【代码3】:

Index.aspx.cs

   View.aspx代码如下:

ViewData这一成员变量的类型及为上面提到的IList类型。

    

 

<%@PageLanguage="C#"AutoEventWireup="true"CodeBehind="Edit.aspx.cs"Inherits="Northwind.Views.Customer.Edit"%>

DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http:

//www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

//www.w3.org/1999/xhtml">

   

   

       

           

           

           

           

           

           

         

  

           <%foreach(Northwind.Models.CustomercustomerinViewData)

              {%>

              

                 

—URL指向CustomerContoller的Edit方法-->

                 

                 

                 

                 

                 

                 

              

              <%}%>

       

EditCustomerIDCompanyNameContactNameContactTitle
">Edit <%=customer.CustomerID%><%=customer.CompanyName %><%=customer.ContactName %><%=customer.ContactTitle %>

   

   【代码4】:

Index.aspx

   下面来实现CustomerController的Edit方法。

在CustomerController.cs中添加如下代码:

    

 

publicvoidEdit(stringid)

{

           Northwind.Models.NorthwindDataContextdc=newNorthwind.Models.NorthwindDataContext();

           Customerc=dc.Customers.Single(cus=>cus.CustomerID==id);//从数据库中取出参数id所对应的的一个Customer记录

           RenderView("Edit",c);//返回EditView

    

   【代码5】:

CustomerController.cs中的Edit方法

   相应的在项目中的View/Customer/文件夹下,添加EditViewEdit.aspx:

    

 

publicpartialclassEdit:

ViewPage

{

}

    

   【代码6】:

Edit.aspx.cs

    

   

 

<%@PageLanguage="C#"AutoEventWireup="true"CodeBehind="Edit.aspx.cs"Inherits="Northwind.Views.Customer.Edit"%>

DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http:

//www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

//www.w3.org/1999/xhtml">

   

—下面的htmlform将用户的输入提交到CustomerContoller的Update方法-->

<%using(Html.Form(cc=>cc.Update(ViewData.CustomerID))){%>

   

      CustomerID:

<%=ViewData.CustomerID %>

      CompanyNmae:

<%=Html.TextBox("Customer.CompanyName",ViewData.CompanyName)%>

      ContactName:

<%=Html.TextBox("Customer.ContactName",ViewData.ContactName)%>

      ContactTitle:

<%=Html.TextBox("Customer.ContactTitle",ViewData.ContactTitle)%>

   

   <%=Html.SubmitButton("Save")%>

   <%}%>

    

   【代码7】:

Edit.aspx

   代码7中使用了MVC框架中的一个帮助类Html。

此类可以生产View中常用的界面元素,例如htmlform,文本输入框等。

   下面来

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 数学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1