首页 > 代码库 > 浅谈MVC与三层架构

浅谈MVC与三层架构

  首先给大家引入下MVC的概念:

  MVC(Model View Controller)模型、视图以及控制器,它是一种较为广泛应用的结构设计模式。

  模型:就是在MVC设计模式中需要被显示的数据。在通常情况下,该模型需要从数据库中读取数据、保存模型的状态等,提供数据的访问方法以及数据的维护。

  视图:就是用来显示模型中数据的用户界面,一般来书,视图就是HTML页面。

  控制器:就是用来处理对用户的输入或者交互命令,以便改变模型的状态,选择适当的视图来显示对应的模型数据。

  工作机制如右图所示:

  (1)用户向控制器发出请求。

  (2)控制器收到用户请求后,向模型请求获得相关的数据。

  (3)模型将对应的数据返回给控制器。

  (4)控制器将有关数据发送到指定的视图。

  (5)视图将数据呈现给用户。

  通过上面的介绍相信大家对于MVC也有了一定的了解和认识,那么MVC与原先我们学习过的三层架构到底有哪些相同点,又有哪些不同之处呢?

  MVC与三层的共同点:

  MVC与三层架构的触发点事相同的——分层,解耦。它们都做到了显示与数据的分离,大大降低了系统的耦合性。

  但是从专业角度来说MVC与三层没有任何关系,三层是三层,MVC是MVC。唯一能把他们联系在一起的就是“三”这个字了,不过从初学者的角度把二者放在一起区分起来学习也更容易理解。

  MVC与三层的不同点:

  可以说它们之间除了相同的剩下的全是不同点。它们有着各自的工作机制详情请见下图:

  

  三层中的UI在MVC中被分解为View和Controller,BLL和DAL被合并为Model。另外在三层中虽然叫做三层架构,但是我们可以根据需要分为多层。三层中也涉及到Model,但是三层里面的Model跟MVC中的Model完全是两回事,三层中的Model是表实体,而MVC中的Model中包括业务逻辑和数据访问。

  MVC对于Web Form的特点:

  (1)易于单元测试

  (2)容易实施测试驱动开发

  (3)易于扩展和替换

  (4)支持Web Form中的有关特性

  (5)URL被映射到控制器

  虽然MVC对于Web Form有一些新的特性,但是MVC并不能替代传统的Web Form技术,这两种技术只是应用在不同场景,具有不同的优、缺点。不能片面的说那种技术高那种技术低,开发者需要根据自己的实际情况选择相应的技术开发项目。以上是个人通过查阅相关资料对MVC于三层架构之间的一些认识,有不足之处,请大家批评指正。

浅谈MVC与三层架构