news 2026/6/15 2:27:31

【大前端】【Android】一文详解Android MVVM 模式详情解析

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【大前端】【Android】一文详解Android MVVM 模式详情解析

Android MVVM 模式详情解析

一、为什么需要 MVVM?

在早期 Android 开发中,常见架构是:

  • Activity / Fragment = 上帝类

  • UI 控制 + 业务逻辑 + 网络请求 + 数据处理 全部混在一起

典型问题:

  • ❌ Activity 过于臃肿(上千行)

  • ❌ 逻辑与 UI 强耦合,难以测试

  • ❌ 页面复用性差

  • ❌ 维护成本极高

👉MVVM(Model–View–ViewModel)的核心目标:

分离 UI 与业务逻辑,让界面只负责展示,逻辑由 ViewModel 处理


二、MVVM 架构概览

1️⃣ 架构组成

View(Activity / Fragment) ↓ 观察 ViewModel ↓ 调用 Model(Repository / DataSource)
层级职责
View负责 UI 展示、事件分发
ViewModel负责业务逻辑、状态管理
Model数据来源(网络 / 数据库 / 本地)

三、各层职责详解

1️⃣ View(Activity / Fragment)

只做三件事:

  1. 初始化 UI

  2. 监听 ViewModel 数据变化

  3. 把用户操作交给 ViewModel

❌ View不应该做的事情

  • 网络请求

  • 数据解析

  • 业务判断

示例:

class UserActivity : AppCompatActivity() { private val viewModel: UserViewModel by viewModels() override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_user) viewModel.userLiveData.observe(this) { // 只负责刷新 UI textView.text = it.name } button.setOnClickListener { viewModel.loadUser() } } }

2️⃣ ViewModel(核心)

ViewModel 是 MVVM 的灵魂

职责:

  • 处理业务逻辑

  • 保存 UI 状态

  • 提供可观察数据(LiveData / StateFlow)

特点:

  • 不持有 View 的引用

  • 生命周期比 Activity 长(配置变更不销毁)

  • 可单元测试

示例:

class UserViewModel( private val repository: UserRepository ) : ViewModel() { private val _userLiveData = MutableLiveData<User>() val userLiveData: LiveData<User> = _userLiveData fun loadUser() { viewModelScope.launch { val user = repository.getUser() _userLiveData.value = user } } }

3️⃣ Model(数据层)

通常由Repository 模式组成:

Repository ├── RemoteDataSource(网络) └── LocalDataSource(数据库 / 缓存)

Repository 的职责:

  • 屏蔽数据来源

  • 统一数据入口

  • 控制缓存策略

示例:

class UserRepository( private val api: UserApi ) { suspend fun getUser(): User { return api.getUser() } }

四、MVVM 中的数据驱动思想

1️⃣ 核心理念

UI = 数据的映射结果

不再主动“刷新 UI”,而是:

  • 数据变 → UI 自动更新

Android 常用方案:

技术场景
LiveData传统 Android
StateFlowKotlin 协程
DataBindingXML 直接绑定

2️⃣ LiveData vs StateFlow

对比项LiveDataStateFlow
生命周期感知否(需 repeatOnLifecycle)
Kotlin 友好一般非常好
冷/热流
推荐程度⭐⭐⭐⭐⭐⭐⭐

五、MVVM + Jetpack 推荐组合

官方推荐:

MVVM + ViewModel + LiveData / StateFlow + Room + Retrofit + Hilt

示意图:

UI → ViewModel → Repository → DataSource ↑ StateFlow

六、常见错误 & 反模式

❌ 1. ViewModel 持有 Context / View

class BadViewModel(val context: Context) // ❌

✅ 正确方式:

  • 把资源、Toast、跳转交给 View

  • 或使用 Event 通知


❌ 2. ViewModel 过度膨胀

把所有逻辑都塞进 ViewModel

✅ 建议:

  • 复杂逻辑下沉到 UseCase / Domain 层

  • ViewModel 只做“协调者”


❌ 3. LiveData 用来做一次性事件

例如 Toast / 跳转:

LiveData<Boolean> // ❌ 会重复触发

✅ 正确方式:

  • SingleLiveEvent

  • Channel / SharedFlow


七、进阶:MVVM + Clean Architecture

View ↓ ViewModel ↓ UseCase ↓ Repository ↓ DataSource

优势:

  • 更易测试

  • 复杂业务可控

  • 大型项目首选


八、MVVM 的优缺点总结

✅ 优点

  • 清晰分层

  • UI 与逻辑解耦

  • 易测试

  • 生命周期安全

❌ 缺点

  • 初学成本高

  • 小项目略显“重”

  • 设计不当仍会臃肿


九、什么时候该用 MVVM?

项目规模是否推荐
Demo / 小工具
中型 App
大型 / 长期维护项目⭐⭐⭐⭐

十、一句话总结

MVVM 的本质是:用数据驱动 UI,用 ViewModel 隔离复杂性


版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 9:31:40

47、网络通信与安全:VoIP与SSH的深入解析

网络通信与安全:VoIP与SSH的深入解析 1. VoIP 基础与 Asterisk 管理 在 VoIP(Voice over Internet Protocol)领域,Asterisk 是一款强大的开源软件,可用于搭建功能完备的 VoIP 系统。 1.1 Asterisk 控制台输出与测试 当呼叫断开后,Asterisk 控制台可能会显示如下示例输…

作者头像 李华
网站建设 2026/6/15 9:32:32

AFE为何物

AFE 的全称是Analog Front-End&#xff0c;中文为模拟前端芯片&#xff0c;它是 BMS&#xff08;电池管理系统&#xff09;中负责电池核心参数采集与初步处理的关键专用芯片&#xff0c;也是高串数电池包&#xff08;如新能源车、储能电站电池&#xff09;的核心组件。 核心功…

作者头像 李华
网站建设 2026/6/15 10:25:43

Cesium快速入门20:Primitive的外观设置Appearance

前面我们学会了用 Entity 换皮肤&#xff1b;今天轮到 Primitive——自己捏几何体后&#xff0c;再给它穿什么样的“外衣”。 在 Cesium 里&#xff0c;这件外衣叫 Appearance&#xff08;外观&#xff09;。 它决定“像素怎么画、用什么材质、要不要光照”等所有渲染细节。 上…

作者头像 李华
网站建设 2026/6/15 10:28:18

单车慢跑中的节奏建议

单车定向的几个问题第21届智能车竞赛单车定向组比赛科目细则 01 单车定向中的慢跑 一、漫无目的 卓大单车还有如果这样跑可以吗&#xff1f; 我感觉这么跑的话就无线循环了&#xff0c;应该也在规则里ban了吧。 单车的两个公司的舵机可以混着用吗&#xff1f;   比如在k1车模…

作者头像 李华
网站建设 2026/6/15 10:27:40

昇腾Ascend C Add算子开发实战-从理论到代码的完整构建

目录 1 摘要 2 技术原理 2.1 架构设计理念解析 2.2 核心算法实现 2.2.1 核函数基础架构 2.2.2 三级流水线实现 2.3 性能特性分析 2.3.1 理论性能模型 2.3.2 实测性能数据 3 实战部分 3.1 完整可运行代码示例 3.2 分步骤实现指南 步骤1&#xff1a;环境配置与工程创…

作者头像 李华