MVC神韵---你想在哪解脱!(一)
MVC模式
MVC模式是一种软件架构模式。它把软件系统分为三个部分:模型(Model),视图(View)和控制(Controller)。
MVC模式最早由Trygve Reenskaug在1974年提出,是施乐帕罗奥多研究中心(Xerox PARC)在20世纪80年代为程序语言Smalltalk发明的一种软件设计模式。MVC模式的目的是实现一种动态的程序设计,使后续对程序的修改和扩展简化,并且使程序某一部分的重复利用成为可能。除此之外,此模式通过对复杂度的简化,使程序结构更加直观。软件系统通过对自身基本部份分离的同时也赋予了各个基本部分应有的功能。
模型(Model) “领域业务数据模型”(Model)用于封装与应用程序的业务逻辑相关的数据以及对数据的处理方法。“模型”有对数据直接访问的权力,例如对数据库的访问。“模型”不依赖“视图”和“控制器”,也就是说,模型不关心它会被如何显示或是如何被操作。但是模型中数据的变化一般会通过一种刷新机制被公布。为了实现这种机制,那些用于监视此模型的视图必须事先在此模型上注册,从而,视图可以了解在数据模型上发生的改变.
视图(View) 视图层能够实现数据有目的的显示(理论上,这不是必需的)。在视图中一般没有程序上的逻辑。为了实现视图上的刷新功能,视图需要访问它监视的数据模型(Model),因此应该事先在被它监视的数据那里注册。UI的形式由模型数据而变,一种模型数据结果可以有很多不同的UI视图表达形式。
控制器(Controller) 控制器起到不同层面间的组织作用,用于控制应用程序的流程。它处理事件并作出响应。“事件”包括用户的行为和数据模型上的改变。
多个视图能共享一个模型。如今,同一个Web应用程序会提供多种用户界面,例如用户希望既能够通过浏览器来收发电子邮件,还希望通过手机来访问电子邮箱,这就要求Web网站同时能提供Internet界面和WAP界面。在MVC设计模式中,模型响应用户请求并返回响应数据,视图负责格式化数据并把它们呈现给用户,业务逻辑和表示层分离,同一个模型可以被不同的视图重用,所以大大提高了代码的可重用性。
其次,控制器是自包含(self-contained)指高独立内聚的对象,与模型和视图保持相对独立,所以可以方便的改变应用程序的数据层和业务规则。例如,把数据库从MySQL移植到Oracle,或者把RDBMS数据源改变成LDAP数据源,只需改变控制器即可。一旦正确地实现了控制器,不管数据来自数据库还是LDAP服务器,视图都会正确地显示它们。由于MVC模式的三个模块相互独立,改变其中一个不会影响其他两个,所以依据这种设计思想能构造良好的少互扰性的构件。
此外,控制器提高了应用程序的灵活性和可配置性。控制器可以用来连接不同的模型和视图去完成用户的需求,也可以构造应用程序提供强有力的手段。给定一些可重用的模型和视图,控制器可以根据用户的需求选择适当的模型机型处理,然后选择适当的的视图将处理结果显示给用户。
MVC
三种角色:
--Model:用于存储领域业务数据的组件
--View:根据Model数据进行内容UI展示的组件
--Controller:接受并处理用户指令(操作Model),选择一个View并输出内容。
Controller对View进行引用,但是View不知道Controller的存在。Controller和View都是单向引用Model
MVC变种:Observer模式,MVP模式。
MVC与三层架构:
三层架构是一种架构模式,它有很明显的层次关系,而MVC是一种表现模式,其中的三个元素没有层次上的先后关系,只是组件之间的协作。
ASP.NET MVC的组件协作(基本流程)
URL-->Controller(会执行一个方法Action)-->从数据库中获取一个Model对象-->将Model作为ViewData传递给View(Detail.aspx)。
主要的几个步骤:URL Routing,Controller&Action Executing,View Rendering
URL Routing: ASP.NET MVC使用的是URL进行驱动的,根据程序中指定的规则从URL中确定Controller名,Action名,其他参数。
System.Web.Routing.dll。独立于ASP.NET MVC框架的组件,可用于任何ASP.NET应用程序。作用是将URL转换为RouteData等数据。
使用:
1>.配置UrlRoutingModule。
2>.在Application_Start时添加规定,这里需要注意锁定的问题(由于Web应用程序天生是多线程的)。
3>.规则的顺序。
4>.RouteExistingFiles属性。
在Global.asax文件中定义:
//URL规则的定义
public static void RegisterRoutes(RouteCollection routes)
{
routes.MapRoute(
"Default",
"{controller}/{action}/{id}",
new {action="Index",id=0},
new {controller=@"^\w+",id=@"\d+"});
//Car/bnw.abc
routes.MapRoute(
"Car",
"Car/{make}.{model}",
new {controller="car",action="Index"},
new {make=@"(acural|bnw)"});
}
protect void Application_Start()
{
RegisterRoutes(RouteTable.Routes);
RouteTable.Routes.RouteExistingFiles=true;
}
如果URL访问的是磁盘上的一个物理文件,默认情况下不会被URL Routing,可以用RouteTable.Routes.RouteExistingFiles=true;避免。
Routing和URL Rewrite的区别:
URL Rewrite:改变程序处理的URL(ASP.NET WebFrom)
URL Route: 根据URL的规则选择执行(MVC)
~~~~待续~~~~