1. Compose诞生背景

近年来,以React为代表的声明式UI开发思想席卷了整个前端开发领域。客户端与前端在产品形态上非常相似,也希望借鉴这种全新的开发思想来提升客户端UI的开发效率和体验。在这个大背景下,AndroidiOS平台相继发布了自己的声明式UI开发框架。而在Android中的明式UI开发框架就是Compose

2. Compose的优势

2.1 官方的描述

先来看下官网上的描述 :
Jetpack Compose 是推荐用于构建原生 Android 界面的新工具包。它可简化并加快 Android 上的界面开发,使用更少的代码、强大的工具和直观的 Kotlin API,快速打造生动而精彩的应用。

Android compose详解 安卓 compose_kotlin


是不是有点抽象 ? 所以我又重新罗列了一下Compose的优势,如下

2.2 声明式UI

不需要手动刷新数据,只需描述界面,Compose会负责处理剩余的工作。应用状态变化的时候,界面会自动更新。这是Compose极其重要的一个特性。

2.2.1 声明式UI和命令式UI的区别

命令式 UI 就是命令框架怎么做,最终达到我们做什么的目的。
声明式 UI 就是告诉框架做什么具体怎么做我们不关心

相当于命令式 UI是房地产包工头,建房子得亲自下场,指挥建什么,怎么建。
而声明式UI是房地产老板,只需要关心建几栋,建在哪里,建成什么样就可以了,具体的建造过程不需要关心。

声明式 UI 其实是将“怎么做”这部分做了封装,让我们专注于“做什么”

2.3 去除了XML

使用 xml + Kotlin (Java) 开发,不可避免地涉及到两种语言的交互,就会有局限性,比如布局id要生成R资源ID,用java要找到View,进行为空判断啥的,所以才会出现诸如Butter KnifeDataBindingViewBinding之类的库。

Compose 只使用 Kotlin 一种语言,用 Kotlin 来代替 xml 文件写布局,代码会自由和方便得多。完全解除了混合写法(xml + Java、Kotlin)的局限性,再也不需要 findViewById

2.4 精简代码数量

作为代码开发者,需要测试和调试的代码会更少,出现 bug 的可能性也更小,可以专注于解决手头的问题;作为审核人员或维护人员,需要阅读、理解、审核和维护的代码更少

  • 精简代码数量 ,能减少bug的出现
  • 实现同样的功能只需要以前一半的代码量
  • 无论要构建什么,都很简洁且易于维护

2.5 超强兼容性

Compose 与所有的现有代码兼容:可以从 View 调用 Compose 代码,也可以从 Compose 调用 View

  • 兼容现有的所有代码,Compose 能够与现有 View 体系并存,这意味着可实现渐进式替换
  • 大多数常用库(如 NavigationViewModelKotlin 协程)都适用于 Compose
  • 最低兼容到 API 21,支持市面上绝大多数Android设备的使用。

2.6 加速开发

Compose 为我们提供了很多开箱即用的API,内置对 Material Design、深色主题、动画等的支持,
可以节省不少精力,能够让我们快速创建精美的应用。

  • 得益于良好的架构分层,可以基于任意一层进行构建。
  • 利用 Compose,可以轻松快速地通过动画让应用变得生动有趣
  • 借助全面的 Android Studio 支持以及实时预览等功能,可以更快地迭代和交付代码

2.6.1 Compose模块分层

Compose从上到下分为四层,每一层都可以单独使用,在不同维度提供能力支持。

Compose模块

说明

Material

此模块位于最上层,基于Material Design系统实现的各种Composable

Foundation

此模块为UI提供了一些基础的Composable,例如Row、Column、lazyColumn等布局类UI,以及特定手势识别等,这些基础Composable在很多平台都可以通用

UI

此模块构筑了上层Composable运行的基础,例如Composable的测量、布局、绘制、事件处理以及Modifier管理等

Runtime

此模块提供了基本的对UI树的管理能力,如果只需要Compose的树管理能力,而不需要其UI,则可以直接基于此层进行构建

这意味着未来一定会出现很多Compose的UI主题库,基于Foundation来实现,类似于 前端的UI库,等Compose生态成熟后,就会有很多的UI主题库可以使用啦。

3. 小结