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

相关推荐
pe7er40 分钟前
使用 Vue 官方脚手架创建项目时遇到 Node 18 报错问题的排查与解决
前端·javascript·vue.js
pe7er1 小时前
使用 types / typings 实现全局 TypeScript 类型定义,无需 import/export
前端·javascript·vue.js
islandzzzz1 小时前
(第二篇)HMTL+CSS+JS-新手小白循序渐进案例入门
前端·javascript·css·html
喝拿铁写前端1 小时前
前端实战优化:在中后台系统中用语义化映射替代 if-else,告别魔法数字的心智负担
前端·javascript·架构
超人不会飛2 小时前
就着HTTP聊聊SSE的前世今生
前端·javascript·http
蓝胖子的多啦A梦2 小时前
Vue+element 日期时间组件选择器精确到分钟,禁止选秒的配置
前端·javascript·vue.js·elementui·时间选选择器·样式修改
夏天想2 小时前
vue2+elementui使用compressorjs压缩上传的图片
前端·javascript·elementui
The_cute_cat2 小时前
JavaScript的初步学习
开发语言·javascript·学习
海天胜景2 小时前
vue3 el-table 列增加 自定义排序逻辑
javascript·vue.js·elementui
烛阴2 小时前
XPath 进阶:掌握高级选择器与路径表达式
前端·javascript