目录
1 到底什么是 MVC" >1 到底什么是 MVC
2 我遇到了什么问题" >2 我遇到了什么问题
3 View的职责" >3 View的职责
4 Model的职责" >4 Model的职责
5 Controller的职责" >5 Controller的职责
6 启示" >6 启示
首页 后端开发 php教程 实例讲解MVC架构的含义及职责划分

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

Jan 07, 2022 pm 02:09 PM
mvc架构

最近负责一个项目,用了 Yii Framework 的 MVC 框架,刚开始自以为结构很稳健。

但是随着对业务逻辑理解的深入,才开始意识到问题的严重。

我错误地理解了 MVC 中的 Controller,想当然地根据以往的经验,把所有的业务逻辑都放在 Controlleraction 中去实现。

于是,每一个 Controller代码都上千行,越来越臃肿

最后,我下定决心重构代码,起源是一个对外开放 API 接口的需求。

按照现在的架构,代码基本无法复用,我需要把很多功能再重复写一遍,这实在是无法接受。

面向对象编程不仅仅是课本上的名词啊!

真正开始实践才发现,要有面向对象意识,有全局观,是多么难得的一件事情。

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

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架构的含义及职责划分的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

PHP实现MVC架构:基本原理及应用 PHP实现MVC架构:基本原理及应用 Jun 18, 2023 pm 01:13 PM

PHP实现MVC架构:基本原理及应用MVC(Model-View-Controller)是一种常见的软件设计模式,它是一种将应用程序分成三个核心组件(模型、视图、控制器)的方式。这种模式的主要目的是将代码分离成独立的构建块,以增强开发的可维护性、可扩展性和可重用性。在Web开发中,MVC已成为最流行的设计模式之一。PHP作为Web开发的一种流行语言之一,建

如何通过PHP8框架实现安全的MVC架构 如何通过PHP8框架实现安全的MVC架构 Sep 11, 2023 am 08:21 AM

如何通过PHP8框架实现安全的MVC架构随着互联网的快速发展,Web应用程序在我们生活中扮演着越来越重要的角色。然而,随着Web应用程序的复杂性增加,安全问题也成为了一个不容忽视的关键问题。为了保护应用程序及用户的数据安全,我们需要采用合适的架构和技术手段来确保应用程序的安全性。在PHP开发中,采用MVC架构是一种常见的做法。而在PHP8框架中,我们可以利用

如何在PHP8框架中构建有效的MVC架构 如何在PHP8框架中构建有效的MVC架构 Sep 12, 2023 pm 03:18 PM

如何在PHP8框架中构建有效的MVC架构MVC(Model-View-Controller)是一种常见的软件设计模式,用于为应用程序提供一种有效的组织架构。在PHP开发中,MVC模式是开发人员提高代码可维护性和可扩展性的重要工具。本文将介绍如何在PHP8框架中构建一个有效的MVC架构。一、框架选择选择一个适合的框架是构建MVC架构的第一步。PHP8目前有许多

PHP中的MVC架构的实现及常见问题解答 PHP中的MVC架构的实现及常见问题解答 Jun 08, 2023 pm 02:19 PM

在Web开发中,MVC架构模式常被应用于Web应用程序的开发中。而在PHP开发中,MVC架构得到了广泛的应用,为Web应用程序的开发提供了有效的解决方案。本文将介绍PHP中的MVC架构的实现方式及其常见问题解答。一、MVC架构模式简介MVC是一种软件开发的架构模式,它主要由三个组成部分构成:Model(模型)、View(视图)和Controller(控制器)

MVC架构解析 -- 理解Web应用的基本原理 MVC架构解析 -- 理解Web应用的基本原理 Sep 08, 2023 am 10:48 AM

MVC架构解析--理解Web应用的基本原理MVC(Model-View-Controller)架构是一种常用于构建Web应用程序的软件设计模式。它将应用程序分为三个基本组成部分:模型(Model)、视图(View)和控制器(Controller)。每个部分负责不同的功能,相互之间协同工作,使得应用程序更加清晰、可维护和可扩展。模型(Model)模型是应用

php如何使用CakePHP框架? php如何使用CakePHP框架? May 31, 2023 pm 02:51 PM

在现代Web开发中,使用MVC框架能够大大提高开发效率和代码可维护性。CakePHP是一款基于MVC设计模式的PHP框架,其易用性和灵活性使得它受到了许多开发者的喜爱。在这篇文章中,我们将介绍如何使用CakePHP框架来开发Web应用程序。准备工作在使用CakePHP之前,需要你安装以下软件:PHP5.6或更高版本MySQL5.5或更高版本Apache服

如何在PHP8框架中实现可扩展和可维护的MVC架构 如何在PHP8框架中实现可扩展和可维护的MVC架构 Sep 11, 2023 am 08:49 AM

如何在PHP8框架中实现可扩展和可维护的MVC架构引言:随着Web应用程序的不断发展,MVC(模型-视图-控制器)架构成为了一种被广泛采用的设计模式。它可以帮助开发者将应用程序的逻辑、视图和数据分离,提高代码的可扩展性和可维护性。在本文中,将介绍如何在PHP8框架中实现一个可扩展和可维护的MVC架构。一、了解MVC架构MVC架构由三个主要的组件组成:模型(M

Yii的架构:MVC等 Yii的架构:MVC等 Apr 11, 2025 pm 02:41 PM

Yii框架采用MVC架构,并通过组件、模块等增强其灵活性和扩展性。1)MVC模式将应用逻辑分为模型、视图和控制器。2)Yii的MVC实现通过动作细化请求处理。3)Yii支持模块化开发,提升代码组织和管理。4)使用缓存和数据库查询优化可提升性能。

See all articles