【WEEK1】【 DAY1】 MVC相关历史和概念【中文版】

2024.2.26 Monday

1. 什么是MVC

  1. MVC是模型(Model)、视图(View)、控制器(Controller)的简写,是一种软件设计规范。
  2. 是将业务逻辑、数据、显示分离的方法来组织代码。 MVC主要作用是降低了视图与业务逻辑间的双向偶合。
  3. MVC不是一种设计模式,MVC是一种架构模式。当然不同的MVC存在差异。
  • Model(模型):数据模型,提供要展示的数据,因此包含数据和行为,可以认为是领域模型或JavaBean组件(包含数据和行为),不过现在一般都分离开来:Value Object(数据Dao) 和 服务层(行为Service)。也就是模型提供了模型数据查询和模型数据的状态更新等功能,包括数据和业务。
  • View(视图):负责进行模型的展示,一般就是我们见到的用户界面,客户想看到的东西。
  • Controller(控制器):接收用户请求,委托给模型进行处理(状态改变),处理完毕后把返回的模型数据返回给视图,由视图负责展示。也就是说控制器做了个调度员的工作。
  • 最典型的MVC就是JSP + servlet + javabean的模式。
    在这里插入图片描述

2. Model1时代

  1. 在web早期的开发中,通常采用的都是Model1
  2. Model1中,主要分为两层,视图层和模型层
  3. Model1优点:架构简单,比较适合小型项目开发
  4. Model1缺点:JSP职责不单一,职责过重,不便于维护

3. Model2时代

Model2把一个项目分成三部分,包括视图、控制、模型。

  1. 用户发请求
  2. Servlet接收请求数据,并调用对应的业务逻辑方法
  3. 业务处理完毕,返回更新后的数据给servlet
  4. servlet转向到JSP,由JSP来渲染页面
  5. 响应给前端更新后的页面

4. 职责分析

  1. Controller:控制器
  • 取得表单数据
  • 调用业务逻辑
  • 转向指定的页面
  1. Model:模型
  • 业务逻辑
  • 保存数据的状态
  1. View:视图
  • 显示页面
  1. Model2的优点:Model2这样不仅提高的代码的复用率与项目的扩展性,且大大降低了项目的维护成本。Model 1模式的实现比较简单,适用于快速开发小规模项目,Model1中JSP页面身兼View和Controller两种角色,将控制逻辑和表现逻辑混杂在一起,从而导致代码的重用性非常低,增加了应用的扩展性和维护的难度。Model2消除了Model1的缺点。