三层架构 + MVP 到底怎么结合?如何体现?

三层架构 + MVP 到底怎么结合?如何体现?


一、先把两个概念彻底分开(非常关键)

1. 三层架构(UI-BLL-DAL)

目的:分离界面、业务、数据,解决"代码乱、难维护"

  • UI 层:界面、按钮、输入框
  • BLL 层:业务逻辑、验证、计算
  • DAL 层:数据库增删改查
  • Model:实体类(贯穿三层)

2. MVP(View-Presenter-Model)

目的:分离界面逻辑与界面渲染,解决"界面代码臃肿"

  • View:界面(只显示,不处理逻辑)
  • Presenter:逻辑处理中心
  • Model:数据/实体

二、核心结论(一句话)

MVP 是跑在 UI 层内部的架构,用来把 UI 层再拆干净!

三层架构是整体项目架构,MVP 是 UI 层的内部架构!

它们不是竞争关系,是嵌套关系


三、可视化图画:三层架构 + MVP 如何体现

🎨 终极整合图(最标准、最漂亮)

复制代码
┌─────────────────────────────────────────────────────┐
【  三  层  架  构  全  局  图  】
└─────────────────────────────────────────────────────┘

┌─────────────────────────────────────────────────────┐
│                  UI 层 (最上层)                     │
│  ┌─────────────┐         ┌──────────────────────┐   │
│  │   View      │←-------→│      Presenter       │   │
│  │ (界面)    │   MVP   │ (UI逻辑处理中心)    │   │
│  └─────────────┘         └──────────┬───────────┘   │
└─────────────────────────────────────┼────────────────┘
                                      │
                                      ▼
┌─────────────────────────────────────────────────────┐
│                  BLL 层 (业务逻辑)                  │
│              业务验证、规则、组合逻辑                │
└─────────────────────────────────────┬────────────────┘
                                      │
                                      ▼
┌─────────────────────────────────────────────────────┐
│                  DAL 层 (数据访问)                  │
│                数据库、EF、SQL 操作                  │
└─────────────────────────────────────────────────────┘

                      ↑
                      │
               Model(实体类)贯穿所有层

四、深度说明:MVP 在三层里如何体现

1. View 只属于 UI 层

  • 只做界面显示
  • 不写业务逻辑
  • 不调用 BLL/DAL
  • 不访问数据库

体现:

View 是纯粹的界面,只暴露接口给 Presenter。


2. Presenter 是 UI 层的"大脑",但不属于界面

Presenter 完全独立于窗体,它:

  • 接收 View 的事件
  • 调用 BLL 层
  • 接收 BLL 返回的数据
  • 控制 View 显示

体现:

Presenter 是 UI 层与 BLL 层之间的桥梁


3. BLL、DAL 不变,还是标准三层

  • BLL:业务逻辑
  • DAL:数据访问
  • Model:实体

体现:

三层架构完全不受影响,MVP 只是让 UI 层更干净。


五、最清晰的调用链(必背!)

用户点击查询按钮 → 完整流程

复制代码
View(界面)
   ↓ 通知事件
Presenter(逻辑中心)
   ↓ 调用业务
BLL 层
   ↓ 调用数据
DAL 层
   ↓ 查数据库
返回数据 → BLL → Presenter → View 显示

六、为什么要在三层里用 MVP?(核心价值)

不加 MVP:

复制代码
UI 层按钮点击
   ↓
直接调用 BLL、DAL
   ↓
界面.cs 文件几千行,维护灾难

加 MVP:

复制代码
界面只管显示
逻辑全部抽到 Presenter
界面和逻辑彻底分离
可测试、可复用、可维护

七、一句话总结(博客最吸睛)

三层架构是项目的整体骨架,MVP 是 UI 层的内部灵魂。

Presenter 就是 UI 层与 BLL 层之间的"干净连接器"。


相关推荐
行乾18 小时前
鸿蒙端 IMSDK 架构探索
架构·harmonyos
石小石Orz18 小时前
油猴脚本实现生产环境加载本地qiankun子应用
前端·架构
若风的雨19 小时前
【deepseek】RISC-V 的CSR寄存器详解
架构
ZHENGZJM20 小时前
架构总览:Monorepo 结构与容器化部署
架构·go·react·全栈开发
搜佛说21 小时前
比SQLite更快,比InfluxDB更轻:sfsDb的降维打击
jvm·数据库·物联网·架构·sqlite·边缘计算·iot
提子拌饭13321 小时前
昼夜节律下的肝脏代谢清除率演算仪:基于鸿蒙Flutter的双路流场与酶解粒子对照架构
flutter·华为·架构·harmonyos·鸿蒙
SuperEugene21 小时前
前端通用基础组件设计:按钮/输入框/弹窗,统一设计标准|组件化设计基础篇
前端·javascript·vue.js·架构
贺小涛1 天前
DeepSeek vs ChatGPT:技术架构深度解析与核心优势对比
chatgpt·架构
Ghost Face...1 天前
Linux USB 全栈解析:OTG + Type-C + PD 内核架构(架构师级)
linux·c语言·架构
be to FPGAer1 天前
架构与微架构设计
架构