来源:https://www.awaimai.com/873.html   歪麦博客

最近负责一个项目,用了 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里面。

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 职能划分_MVC架构的职责划分原则相关推荐

  1. mvc 职能划分_【转】MVC中的操作如何分类(MVC层次的划分)

    原帖地址:http://www.cnblogs.com/elaron/archive/2012/11/02/2751747.html MVC,顾名思义就是Model.View以及Control. 在J ...

  2. java中mvc开发模式_MVC开发模式

    1.1  MVC模式 1.1.1  MVC模式简介 MVC是一种架构型模式,它本身并不引入新的功能,只是用来指导我们改善应用程序的架构,使得应用的模型和视图相分离,从而得到更好的开发和维护效率. 在M ...

  3. 云原生架构及设计原则

    云原生架构及设计原则 云原生(Cloud Native)的概念,由来自Pivotal的MattStine于2013年首次提出,被一直延续使用至今.这个概念是Matt Stine根据其多年的架构和咨询经 ...

  4. 学阿里中台,80%的人只学到了皮毛!揭秘阿里中台的12个架构思维和原则

    戳蓝字"CSDN云计算"关注我们哦! 来源 | 阿里技术官方公众号(ali_tech) 作者|九摩/阿里技术专家 许多企业都忙于学习阿里的中台系统,想通过中台系统,解决企业当前的痛 ...

  5. 开工大吉,重温下架构设计六大原则

    今天是正月初七,我还请假在家,刚刚读了<银河帝国>,读到马洛解决了谢顿危机,成为继哈里谢顿.赛佛哈定之后的第三位英雄.春节过得还不错,休息了.陪伴家人了.学习了.思考了. 重温下架构设计六 ...

  6. 系统架构设计的原则和模式

    1 分层架构 分层架构是最常见的架构,也被称为n层架构.多年以来,许多企业和公司都在他们的项目中使用这种架构,它已经几乎成为事实标准,因此被大多数架构师.开发者和软件设计者所熟知. 分层架构中的层次和 ...

  7. MVC模式与三层架构的区别

    MVC模式与三层架构的区别 原文地址:http://www.cnblogs.com/yourshj/p/5197310.html 之前总是混淆MVC表现模式和三层架构模式,为此记录下. 三层架构和MV ...

  8. 强烈推荐|我做系统架构的一些原则

    本文已授权自骨灰级技术专家陈皓 原文:https://coolshell.cn/articles/21672.html 读完受益匪浅,强烈推荐给大家,都是非常宝贵的经验,希望大家也有收获! 工作 20 ...

  9. 左耳朵耗子:我做系统架构的一些原则

    作者:左耳朵耗子 原文地址:https://coolshell.cn/articles/21672.html 工作 20 多年了,这 20 来年看到了很多公司的很多的系统架构,也看到了很多问题,在跟这 ...

最新文章

  1. 【整理】JDK MacOS X
  2. APP和网站应该选择云主机还是服务器呢?
  3. .NET Core中的验证组件FluentValidation的实战分享
  4. Android同屏或摄像头RTMP推送常用的数据接口设计探讨
  5. ROS学习笔记02:ROS架构与基础
  6. inside the C++ Object model总结
  7. htmlspecialchars_decode 与 html_entity_decode
  8. 数学建模美赛E题数据获取
  9. 小白都能了解的聚类算法之一(Kmeans与GMM)
  10. FPGA-Verilog实例----线性反馈移位寄存器(LFSR)
  11. c语言d是什么意思,c d是什么意思
  12. 高通see架构ppg测试流程sns_client_test_cpp
  13. 基于AT89C51及Proteus仿真的室内火灾监测装置
  14. php查题,2020高校邦《PHP语言程序设计》答案在线查题
  15. 苹果手机上音乐播放的问题
  16. 时间拆分法------高效率的使用完成开发工作之外的剩余时间掌握多门开发语言
  17. c语言编程 人造卫星的高度,C语言实验教学教案2008
  18. Facebook_Pop的使用指北
  19. Predictable Programming on a Precision Timed Architecture
  20. 蓝桥杯C/C++省赛:振兴中华

热门文章

  1. Web API实现微信公众平台开发-服务器验证
  2. 一个情怀引发的生产事故
  3. C#实践设计模式原则SOLID
  4. ASP.NET Core分布式项目实战(Consent 确认逻辑实现)--学习笔记
  5. [Flags]标识的Enum不能使用Html.GetEnumSelectList方法
  6. 开源、免费、企业级的SiteServer CMS .NET CORE 7.0 预览版发布
  7. 使用.NET Core 2.1的Azure WebJobs
  8. .NET Core Community 首个千星项目诞生:CAP
  9. .NET Core 实现定时抓取博客园首页文章信息并发送到邮箱
  10. 聊聊AspectCore动态代理中的拦截器(一)