难得一见 Jetpack MVVM 最佳实践

20,071 阅读3分钟

前言

上周我在 各大技术社区 发表了一篇 《Jetpack MVVM 精讲》,原以为在 知识网红 唱衰安卓 的 2019 会无人问津,没想到文章一经发布,从 国内知名公司 的架构师、技术经理,到 世界级公司 的 Android 开发 都在看。

并且从读者的反馈来看,近期大部分安卓开发 已跳出舒适圈,开始尝试认识和应用 Jetpack MVVM 到实际的项目开发中。

只可惜,关于 Jetpack MVVM,网上多是 东拼西凑、人云亦云、通篇贴代码 的文章,这不仅不能 提供完整的视角 来帮助读者 首先明确背景状况,更是给还没入门 Jetpack 的读者 徒添困扰、起到 劝退 的作用。

好消息是,这一期,我们带着 精心打磨的 Jetpack MVVM 最佳实践案例 来了!

是 爱不释手 的 交互设计!是 连贯 的 用户体验唯一可信源 的 统一分发
222.gif连贯操作.gif统一分发.gif

横竖屏布局 的 无缝切换

444.gif

项目简介

本人拥有 3 年的 移动端架构 践行和设计经验,领导或参与团队重构的 中大型项目 多达十数个,对 Jetpack MVVM 架构在 确立规范化、标准化 开发模式 以 减少不可预期的错误 所作的努力,有着深入的理解。

在这个案例中,我将为你展示,Jetpack MVVM 是如何 以简驭繁 地 将原本十分容易出错、一出错就会耽搁半天时间的开发工作,通过 寥寥的几行代码 轻而易举地完成。

👆👆👆 划重点

在这个项目中,

  • 我们为 横、竖屏 的情况 分别安排了两套 截然不同的布局,并且在 生命周期重建机制状态管理DataBindingViewModelLiveDataNavigation 等知识点的帮助下,通过寥寥几行代码,轻松做到 在横竖屏两种布局间 无缝地切换,并且不产生任何 预期外的错误

  • 我们在多个 Fragment 页面 分别安排了 播放状态 指示器(包括 播放暂停按钮状态、播放列表当前索引指示 等),并向你展示了 如何 以及为何 通过 LiveData 配合 作为唯一可信源 的 ViewModel 或单例,来实现 全应用范围内 可追溯事件 的统一分发

  • 我们在 Fragment 和 Activity 之间分别安排了 跨页面通信,从而向你展示 如何基于 迪米特原则(也称 最少知道原则)、通过 UnPeekLiveData 和 应用级 SharedViewModel 来实现 生命周期安全的、事件源可追溯的 页面通信(事件回调)。

  • 我们在 ui.page data.repositorybridge.request 等目录下,分别安排了 视图控制器、ViewModel 、DataRepository 等 内容,从而向你展示,单向依赖 的架构设计,是如何通过分层的 数据请求和响应,来 规避 内存泄漏 等问题。

  • 本项目的代码一律采用 经过 ISO 认证的 标准化工业级语言 Java 来编写。并且,在上述目录 所包含的 类中,我们大都 提供了丰富的注释,来帮助你理解 骨架代码 为何要如此设计、如此设计能够 在软件工程的背景下 避免哪些不可预期的错误。

除了 在 以简驭繁 的代码中 掌握 MVVM 最佳实践,你还可以 从这个开源项目中 获得的内容 包括:

  1. 整洁的代码风格 和 标准的资源命名规范。
  2. 对 视图控制器 知识点的 深入理解 和 正确使用。
  3. AndroidX 和 Material Design 2 的全面使用。
  4. ConstraintLayout 约束布局的最佳实践。
  5. 优秀的 用户体验 和 交互设计
  6. 绝不使用 Dagger,绝不使用奇技淫巧、编写艰深晦涩的代码。
  7. One More Thing:

The One More Thing is:

详见 GitHub 仓库 Jetpack-MVVM-Best-Practice