Decompose

Decompose

Kotlin多平台组件化开发框架

Decompose是一个Kotlin多平台库,用于构建树状结构的生命周期感知组件。该库提供路由功能和可插拔UI,支持多种UI框架。Decompose实现了UI和业务逻辑的分离,提供导航状态管理、依赖注入等功能,适用于复杂的跨平台应用开发。它支持组件化开发,提高了代码的可测试性和可维护性。

DecomposeKotlin Multiplatform组件化跨平台开发导航功能Github开源项目
<picture> <source media="(prefers-color-scheme: light)" srcset="https://yellow-cdn.veclightyear.com/835a84d5/5790dc93-ba35-4af7-98e0-5b1c1b8797bc.png"> <source media="(prefers-color-scheme: dark)" srcset="https://raw.githubusercontent.com/arkivanov/Decompose/master/docs/media/logo/logo-titled-dark.png"> <img src="https://yellow-cdn.veclightyear.com/835a84d5/5790dc93-ba35-4af7-98e0-5b1c1b8797bc.png" width="300"> </picture> <br/> <br/>

许可证 Twitter链接


Decompose是一个Kotlin多平台库,用于将代码分解为树状结构的生命周期感知业务逻辑组件(又称BLoC),具有路由功能和可插拔UI(Jetpack/Multiplatform Compose、Android Views、SwiftUI、Kotlin/React等)。

请查看项目网站获取文档和API。

如果您有任何问题或想法,可以在讨论部分进行交流。也欢迎加入Kotlin Slack频道 - #decompose

⚡⚡⚡ 所有的星标、问题、讨论、拉取请求等去哪了?

在Badoo/Bumble工作了5年后,我现在开始了另一个冒险。作为过渡的一部分,我被要求将这个仓库转移到Badoo GitHub账户

现在我以副本形式继续这个项目的工作。

这次转移不应该造成任何破坏性变化。大多数外部链接应该没有失效。仓库链接也保持不变:arkivanov/Decompose。如果您认为有什么地方损坏或不正常工作,请在这个仓库中提交问题。

以下是受转移影响最大的方面:

  • 所有星标都被转移了
  • 所有问题和讨论也被转移了。我会尽最大努力填补这里的空白。
  • 所有带有评论历史的拉取请求也都消失了。

我将继续为这个项目和社区尽我所能!一切照常进行!

其他资源:

为什么选择Decompose?

  • Decompose将代码分解成小而独立的组件,并将它们组织成树状结构。每个父组件只知道其直接子组件。
  • Decompose在UI和非UI代码之间划清界限,带来以下好处:
    • 更好的关注点分离
    • 可插拔的平台特定UI(Compose、SwiftUI、Kotlin/React等)
    • 业务逻辑代码可通过纯多平台单元测试进行测试
  • 导航状态完全暴露 - 可插入任何您想要的UI,使用您喜欢的UI框架API或预定义API进行动画处理。
  • 导航是从旧状态到新状态的纯函数 - 无限制导航。
  • 通过构造函数进行适当的依赖注入(DI)和控制反转(IoC),包括但不限于类型安全参数。
  • 共享导航逻辑
  • 生命周期感知组件
  • 后台栈中的组件不会被销毁,它们在后台继续工作,无需UI
  • 状态保存(在Android上自动,在其他目标上通过kotlinx-serialization手动保存)
  • 实例保留(又称ViewModels)以应对配置更改(主要适用于Android)

表情时间!

<img src="https://yellow-cdn.veclightyear.com/835a84d5/8aca0e03-7263-4b6f-aff5-2a4300b350fc.png" width="512">

设置

请查看文档的安装部分。

支持的平台

总的来说,Decompose支持以下目标:androidjvmioswatchostvosmacoswasmJsjs。然而,某些模块不支持所有目标,或者支持取决于Decompose的版本。详情请参阅安装文档。

概述

以下是该库的一些关键概念,更多细节可以在文档中找到。

  • 组件 - 每个组件代表一段具有自己生命周期的逻辑,UI是可选的,可从外部插入
  • ComponentContext - 每个组件都有自己的[ComponentContext],使组件具有生命周期感知能力,并允许状态保存、实例保留(类似于AndroidX的ViewModel)和返回按钮处理
  • 子堆栈 - 实现子组件之间的导航,也支持嵌套导航
  • 子槽 - 一次只允许一个子组件,或者没有
  • 子页面 - 一个子组件列表,有一个选定的组件(例如类似分页器的导航)
  • 通用导航 - 提供一种方法来创建自定义导航模型,当预定义模型都不适合您的需求时
  • 生命周期 - 提供一种方法在组件中监听生命周期事件
  • StateKeeper - 使组件在被销毁时能够保存状态或数据
  • InstanceKeeper - 在组件中保留实例(类似于AndroidX的ViewModel
  • BackPressedHandler - 提供一种方法来处理和拦截返回按钮按压

组件层次结构

<img src="https://yellow-cdn.veclightyear.com/835a84d5/e9319b33-9520-41fb-ac06-0e85e794e08f.png" width="512">

可插拔UI层次结构

<img src="https://yellow-cdn.veclightyear.com/835a84d5/9cb598bc-28e5-41a8-a357-37103cdd3f1f.png" width="512">

典型组件结构

<img src="https://yellow-cdn.veclightyear.com/835a84d5/f9882d19-70ca-4ef5-9821-c8421fcf8948.png" width="512">

快速开始

请参考文档的快速开始部分。

示例

查看文档的示例部分,了解每个示例的完整描述。

模板

查看模板仓库,它可以用来快速启动您的项目。

文章

作者

Twitter:@arkann1985

如果您喜欢这个项目,随时可以<a href="https://www.buymeacoffee.com/arkivanov" target="_blank"><img src="https://yellow-cdn.veclightyear.com/835a84d5/ea36e092-98fc-46e3-a3c2-6b9e0a4227dd.png" alt="给我买杯咖啡" height=32></a> ;-)

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成AI工具AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机AI图像热门
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

下拉加载更多