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

相关推荐
遂心_1 小时前
深入解析前后端分离中的 /api 设计:从路由到代理的完整指南
前端·javascript·api
@大迁世界1 小时前
第7章 React性能优化核心
前端·javascript·react.js·性能优化·前端框架
DownToEarth1 小时前
H5实现获取当前定位
javascript
前端Hardy2 小时前
HTML&CSS:惊艳!科技感爆棚的登录页面代码解析
前端·javascript·html
我是哈哈hh2 小时前
【AJAX项目】黑马头条——数据管理平台
前端·javascript·ajax·前端框架·axios·proxy模式
Ronin-Lotus2 小时前
上位机知识篇---AJAX
前端·javascript·ajax
拾光拾趣录2 小时前
箭头函数 vs 普通函数:从“this 指向混乱”到写出真正健壮的代码
前端·javascript
咔咔一顿操作3 小时前
常见问题三
前端·javascript·vue.js·前端框架
前端程序媛Ying3 小时前
点击按钮滚动到底功能vue的v-on:scroll运用
javascript
yvvvy3 小时前
白嫖 React 性能优化?是的,用 React.memo!
前端·javascript