MVC框架模式学习笔记(一)

来源:互联网 发布:钢铁力量满级s狐狸数据 编辑:程序博客网 时间:2024/06/06 01:28

MVC框架模式简介

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

MVC开始存在于桌面程序中,M指业务模型,V指用户界面,C指控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以有不同的表现形式。比如,一批统计数据可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。

MVC模式是XeroxPARC在二十世纪八十年代为编程语言Smalltalk-80发明的一种框架模式,已被广泛使用。后来被推荐为Oracle旗下Sun公司JavaEE平台的设计模式,并且受到越来越多的使用ColdFusion和PHP的开发者的欢迎。

MVC框架模式内容

MVC是一个框架模式,它强制性地使应用程序的输入、处理和输出分开,从而使应用程序被分成三个核心部件: 模型、视图、控制器。它们各自处理自己的任务。其中,最典型的MVC框架模式是JSP+servlet+ javabean的模式。下面分别介绍三个核心部件:

● 视图: 视图是应用程序看到并与之交互的界面。对老式的web应用程序而言,视图是由HTML元素组成的界面,在新式的Web应用程序中,HTML依旧在视图中扮演着重要的角色,但一些新的技术已层出不穷,如AdobeFlash和像XHTML、XML/XSL、WML等一些语言和Web services。

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

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

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

MVC框架模式特点

  ● MVC框架模式优点

1). 低耦合性

   视图层和业务层分离,这样就允许更改视图层代码而不用重新编译模型和控制器代码,同样,一个应用的业务流程或者业务规则的改变只需要改动MVC的模型层即可。因为模型与控制器和视图相分离,所以很容易改变应用程序的数据层和业务规则。

2). 高重用性

   随着技术的不断进步,需要用越来越多的方式来访问应用程序。MVC模式允许使用各种不同样式的视图来访问同一个服务器端的代码,因为多个视图能共享一个模型,它包括任何WEB(HTTP)浏览器或 者无线浏览器(wap),比如,用户可以通过电脑也可通过手机来订购某样产品,虽然订购的方式不一样,但处理订购产品的方式是一样的。由于模型返回的数据没有进行格式化,所以同样的构件能被不同的界面使用。例如,很多数据可能用HTML来表示,但是也有可能用WAP来表示,而这些表示所需要的命令是改变视 图层的实现方式,而控制层和模型层无需做任何改变。由于已经将数据和业务规则从表示层分开,所以可以最大化的重用代码了。模型也有状态管理和数据持久性处理的功能,例如,基于会话的购物车和电子商务过程也能被Flash网站或者无线联网的应用程序所重用。

3). 生命周期成本低

   MVC是开发和维护用户接口的成本降低了。

4). 部署快

   使用MVC模式使开发时间得到相当大的缩减,它使程序员(Java开发人员)集中精力于业务逻辑,界面程序员(HTML和JSP开发人员)集中精力于表现形式上。

5). 可维护性高

   分离视图层和业务逻辑层也使得Web应用更易于维护和修改。

6). 有利于软件工程化管理

   由于不同的层各司其职,每一层不同的应用具有某些相同的特征,有利于通过工程化、工具化管理程序代码。控制器也提供了一个好处,就是可以使用控制器来联接不同的模型和视图去完成用户的需求,这样控制器可以为构造应用程序提供强有力的手段。给定一些可重用的模型和视图,控制器可以根据用户的需求选择模型进行处理,然后选择视图将处理结果显示给用户。

  ● MVC框架模式缺点

1). 没有明确的定义

   完全理解MVC并不是很容易。使用MVC需要精心的计划,由于它的内部原理比较复杂,所以需要花费一些时间去思考。同时由于模型和视图要严格的分离,这样也给调试应用程序带来了一定的困难。每个构件在使用之前都需要经过彻底的测试。

2). 不适合中小型的应用程序

   花费大量时间将MVC应用到规模并不是很大的应用程序通常会得不偿失。

3). 增加系统结构和实现的复杂性

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

4). 视图与控制器间的过于紧密的连接

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

5). 视图对模型数据的低效率访问

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

6). 一般高级的界面工具或构造器不支持模式

   改造这些工具以适应MVC需要和建立分离的部件的代价是很高的,会造成MVC使用的困难。

   

0 0
原创粉丝点击