您好,欢迎访问一九零五行业门户网

实例讲解MVC架构的含义及职责划分

最近负责一个项目,用了 yii framework 的 mvc 框架,刚开始自以为结构很稳健。
但是随着对业务逻辑理解的深入,才开始意识到问题的严重。
我错误地理解了 mvc 中的 controller,想当然地根据以往的经验,把所有的业务逻辑都放在 controller 的 action 中去实现。
于是,每一个 controller 的代码都上千行,越来越臃肿。
最后,我下定决心重构代码,起源是一个对外开放 api 接口的需求。
按照现在的架构,代码基本无法复用,我需要把很多功能再重复写一遍,这实在是无法接受。
面向对象编程不仅仅是课本上的名词啊!
真正开始实践才发现,要有面向对象意识,有全局观,是多么难得的一件事情。
1 到底什么是 mvc模型-视图-控制器(mvc)是一种设计框架(设计模式)。
mvc 的目标是将业务逻辑从用户界面的考虑中分离。
这样,开发者就可以更容易地改变每一部分而不会影响其他。
在 mvc 中,
model 代表数据和业务规则;view 包含了用户界面元素,例如文本,表单等;controller 则管理模型和视图中的通信。mvc 在各种编程语言中均有实现,例如 j2ee 应用开发中,
view 可能由 jsp 实现;controller 是一个 servlet,现在一般用 struts 实现;model 则是由一个实体 bean 来实现。
2 我遇到了什么问题yii framework 是一个流行的 php 框架,它借鉴了 ruby on rails 的 activerecord(ar) 概念。
数据库中的每一个 table 都可以用 ar 类来方便地进行增删改查操作。
它把 ar 当做 model,并推荐放在一个名为 models 的目录下面。
于是,我在自动生成表对应的 ar 之后,便望文生义想当然地认为已经拥有了 model 层。
其实,ar只不过是 dao (数据访问层),并不是 model 层。
我们的业务几乎全放在了 controller 里:对用户提交上来的表单进行各种逻辑判断,进行计算,实例化 ar 对数据进行存储……
因为一个 controller 中会有多个 action,每个 action 都有这样的业务处理。
最后,我发现我的 controller 代码已经超过了 1000 行。
突然有一天,leader 说,我们这个系统要开放 api 给现有的旧系统调用,要给第三方接口。
第三方只是要给定一个参数,本系统给出个结果值而已,这其中的业务处理它是不关心的。
坏就坏在这里,controller 已经实现了那些业务,但它是接受表单提交的,怎样能够也接受 soap 的 xml 文档呢?
controller 和套套一样,应该越薄越好。
它的职责应该只是接受用户的输入,然后立刻转发给别的类来处理。
这样 controller 只负责提供不同的接口,我们才能算是将业务逻辑分离出去,而分离出去的业务也很容易进行重用。
分离出来的这部分业务由谁来处理呢?答案应该是 model。
3 view的职责view部分比较明确,就是负责显示。
一切与显示界面无关的东西,都不应该出现在view里面。
因此,view 中一般不应该出现复杂的判断语句,以及复杂的运算过程。
可以有简单的循环语句、格式化语句。比如,博客首页的文字列表就是一种循环。
对于php的web应用而言,html是view中的主要内容。
view应该从不调用model的写方法。
也就是说,view只从model中读取数据,但不改写model。
所以我们说,view和model是老死不相往来的。
而且,view中不直接访问$_get和$_post,应该由controller传递给view。
此外,view一般没有任何准备数据处理的内容,如查询数据库等。
这些一般是放在controller里面,并以变量的形式传给视图。
也就是说,视图里面要用到的数据,就是一个变量。
4 model的职责对于model而言,最主要就是保存和输出信息。
比如,post类必然有一个用于保存博客文章标题的title属性,必然有一个删除的操作,这都是model的内容。
数据、行为、方法是model的主要内容。
实际工作中,model是mvc中代码量最大。
model是逻辑最复杂的地方,因为应用的业务逻辑也要在这里表示。
注意将model与controller区分开。
model是处理业务方面的逻辑,controller只是简单的协调model和view之间的关系。
只要是与业务有关的,就该放在model里面。
数据校验、public常量和变量,都应该放在model层,
也就是说,有可能被重复使用的属性或方法,都应该放在model层,一次定义,到处使用。
model不应该访问request、session以及其他环境数据,这些应该由controller注入。
好的设计,应该是胖model,瘦controller。
5 controller的职责对于controller,主要是响应用户请求,决定使用什么视图,需要准备什么数据用来显示。
因此,对于request的访问代码,应该放在controller里面,比如$_get、$_post等。
controller应该仅限于获取用户请求数据,不应该对数据有任何操作或预处理,这应该放在 model 里面。
对于数据的写操作,要调用model类的方法完成。
对于用户请求的响应,要调用视图渲染。
此外,一般不要有html代码等其他表现层的东西,这应该是属于view的内容。
6 启示yii framework 的官方文档中有这么一段:
in a well-designed mvc application, controllers are often very thin, containing probably only a few dozen lines of code; while models are very fat, containing most of the code responsible for representing and manipulating the data.
简言之,rich model is better。
以上就是实例讲解mvc架构的含义及职责划分的详细内容。
其它类似信息

推荐信息