MVC、MVP、MVI、MVVM、MVVM-C和VIPER等

以下是最重要的架构模式列表:

1、MVC(Model-View-Controller):

它是最早被采用的设计模式之一。其主要目标是将应用程序的数据、用户界面和控制逻辑分离成三个相互关联的组件。

在这里,模型Model管理数据和逻辑,视图View显示信息,控制器Controller连接模型和视图,处理用户输入。

适用于数据处理与用户界面明确分离的Web应用程序。

2、MVP(Model-View-Presenter):

该模式由 MVC 演化而来,旨在通过将视图View与模型Model解耦,解决 MVC 在事件驱动环境中的缺陷,而Presenter则充当中间人。

在这里,模型管理数据、视图显示数据,并向Presenter发送用户命令,而Presenter则从模型中检索数据并将其呈现给视图。

用途:强调测试和用户界面逻辑的应用程序,如 Android 应用程序。

3、MVC(Model-View-Intent):

MVI 是一种反应式架构,支持单向数据流,确保给定状态下的用户界面保持一致。

在这里,模型代表状态,视图反映状态,而意图Intent则代表改变状态的用户操作。

用途:注重状态一致性的反应式应用程序或 RxJava 等框架。

4、MVVM(Model-View-ViewModel):

MVVM 的出现是为了解决用户界面开发中的复杂问题,它提倡一种解耦方法,即由 ViewModel 处理视图逻辑,而无需了解用户界面组件。

在这里,Model 管理并显示数据,而 ViewModel 保存并包含与 UI 相关的数据。

用途:用户界面丰富的应用程序或具有数据绑定功能的平台,如 WPF 或具有 LiveData 功能的 Android。

5、MVVM-C(MVVM协调器):

MVVM-C 建立在 MVVM 的基础上,引入了 Coordinator 来处理导航,并将其与 View 和 ViewModel 解耦。

用途:大型应用程序,尤其是 iOS,其中复杂的导航需要与视图逻辑分离。

6、VIPER(View-Interactor-Presenter-Entity-Router):

VIPER 是一种类似于 Clean架构 的模块化架构。它强调可测试性和单一责任原则,将应用逻辑分解为不同的组件。

在这里,视图显示演示者Presenter发送的内容,交互者包含每个用例的业务逻辑,演示者Presenter包含准备内容的视图逻辑,实体包含主模型对象,路由器包含导航逻辑。

https://www.jdon.com/69576.html

相关推荐
kyriewen8 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
free359 小时前
从 0 实现一个 Tiny JavaScript VM:项目架构拆解
javascript
徐小夕11 小时前
我们开源了一款“框架无关”的思维导图编辑器,3分钟集成到任意系统
前端·javascript·github
PBitW11 小时前
GPT训练我的第三天,明白了应该咋说满分回答!😕😕😕
前端·javascript·面试
像我这样帅的人丶你还11 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
labixiong12 小时前
还原一个完整符合规范的 Promise(二)
前端·javascript
To_OC12 小时前
万字解析《JS 语言精粹》之第五章:继承 5 大核心精髓(JS 原型核心)
前端·javascript·代码规范
裕波14 小时前
AI 正在重写应用开发。Vue 与 Vite,给出新的答案。
javascript·vue.js
kyriewen15 小时前
折腾了半年 AI 编程工作流,最后发现效率瓶颈是桌上那块屏幕
前端·javascript·ai编程
张元清17 小时前
React useDebounce Hook:给状态和回调做防抖(2026)
javascript·react.js