Android 开发者 7小时前
Jetpack Navigation 3 | 专为 Compose 打造的全新导航库
index_new5.html
../../../zaker_core/zaker_tpl_static/wap/tpl_guoji1.html

 

Jetpack Navigation 3 是专为 Jetpack Compose 打造的全新导航库,旨在解决传统 Nav2 在Compose应用中的限制。Nav3 采用声明式编程模型和Compose状态,赋予开发者对返回堆栈的完全控制权。它支持自定义动画、预测性返回、多窗格布局等关键功能,并提供模块化设计,简化代码组织。Nav3 目前处于Alpha阶段,开发者可参考官方文档和操作指南开始使用,并分享反馈。

🔗 Nav3采用声明式编程模型和Compose状态,开发者完全掌控返回堆栈,避免状态不一致问题。

🚀 Nav3支持自定义动画和预测性返回,提供灵活API,可在应用和屏幕级别覆写动画效果。

📈 Nav3的Scenes API实现自适应布局,轻松在单窗格和多窗格布局间切换,支持列表-详情等复杂界面。

🧱 Nav3模块化设计,API清晰,便于将导航代码拆分到不同模块,职责分明,提升代码可维护性。

🛠 Nav3提供开放性和可扩展性,开发者可深入底层创建自定义组件,满足个性化导航需求。

原创 Android 2025-08-05 17:31 北京

Jetpack Navigation 3 是一个专为 Jetpack Compose 打造的全新导航库,可帮助您创建灵活的应用导航系统。

作者 / 开发者关系工程师 Don Turner

在应用中的不同屏幕之间导航理应简单明了。然而,构建稳健、可扩展且赏心悦目的导航体验却并非易事。多年来,Jetpack Navigation 库一直是开发者的重要工具,但随着 Android 界面格局的演变,尤其是 Jetpack Compose 的兴起,我们意识到是时候探索一种全新的解决方案了。

我们将在本文为您介绍新推出的 Jetpack Navigation 3,这是一个专为 Compose 打造的全新导航库。为简洁起见,我们将其简称为 Nav3。这个库采用了声明式编程模型和 Compose 状态作为其基本构建模块。


🔗 声明式编程模型

https://developer.android.com/develop/ui/compose/mental-model

🔗 Compose 状态

https://developer.android.com/develop/ui/compose/state

为什么要推出新的导航库?


之前的 Jetpack Navigation 库 (有时也称为 Nav2,因为它是第二个主版本) 最初是在 2018 年发布的,彼时还没有 AndroidX 和 Compose 这两个框架。虽然 Nav2 已经很好地实现了最初目标,但我们了解到,在与现代 Compose 开发模式结合使用时,Nav2 存在一些限制。

其中一个关键的限制是仅支持间接观察返回堆栈状态。这意味着可能存在两个事实来源,从而导致应用状态出现不一致的情况。此外,Nav2 的 NavHost 被设计为仅显示一个目标位置 (即返回堆栈中的最顶层目标位置) 以填充可用空间。这使得实现同时显示多个内容窗格的自适应布局 (例如大屏幕上的列表-详情布局) 变得困难。

△ 从单窗格布局切换到多窗格布局可能会带来导航方面的挑战

创立原则


Nav3 基于以下原则构建而成,旨在提供更大的灵活性并提高开发者掌控力:

△ Nav3 Display 组件观测开发者拥有的返回堆栈的变化


🔗 深入到更低的层级

https://developer.android.com/develop/ui/compose/layering

🔗 操作指南

http://github.com/android/nav3-recipes

关键功能


△ 可以轻松实现自定义动画和预测性返回,并且易于针对各个目标位置进行单独的覆写


🔗 预测性返回

https://developer.android.com/develop/ui/compose/system/predictive-back

🔗 支持自定义动画行为的灵活 API

https://developer.android.com/guide/navigation/navigation-3/animate-destinations

🔗 灵活布局 API

https://developer.android.com/guide/navigation/navigation-3/custom-layouts

🔗 专用 Jetpack lifecycle 库

https://developer.android.com/guide/navigation/navigation-3/save-state#scoping-viewmodels

基本代码示例


为了帮助您了解 Nav3 的工作原理,我们准备了简短的代码示例。

// Define the routes in your app and any arguments.
data object Home
data class Product(val id: String)
// Create a back stack, specifying the route the app should start with.
val backStack = remember { mutableStateListOf<Any>(Home) }
// A NavDisplay displays your back stack. Whenever the back stack changes, the display updates.
NavDisplay(
    backStack = backStack,
    // Specify what should happen when the user goes back
    onBack = { backStack.removeLastOrNull() },
    // An entry provider converts a route into a NavEntry which contains the content for that route.
    entryProvider = { route ->
        when (route) {
            is Home -> NavEntry(route) {
                Column {
                    Text("Welcome to Nav3")
                    Button(onClick = {
                        // To navigate to a new route, just add that route to the back stack
                        backStack.add(Product("123"))
                    }) {
                        Text("Click to navigate")
                    }
                }
            }
            is Product -> NavEntry(route) {
                Text("Product ${route.id} ")
            }
            else -> NavEntry(Unit) { Text("Unknown route: $route") }
        }
    }
)

开始使用并分享反馈


首先,您可以查看开发者文档以及操作指南,其中提供了以下示例:


🔗 开发者文档

https://goo.gle/nav3

🔗 操作指南

https://github.com/android/nav3-recipes

我们计划在未来为更复杂的用例提供代码示例、技术文档和文章。

Nav3 目前处于 Alpha 阶段,这意味着我们可能会根据反馈修改 API。如果您有任何问题或反馈,欢迎分享给我们:

https://issuetracker.google.com/issues/new?component=1750212&template=2102223

Nav3 为在 Compose 应用中构建现代导航提供了灵活而强大的基础。我们非常期待看到您借此打造的精彩作品。

您可以在 io.google 上查看所有 Google I/O 2025 的精彩更新。也欢迎您持续关注 "Android 开发者" 微信公众号,及时了解更多开发技术和产品更新等资讯动态!


🔗 io.google

https://io.google/2025/?utm_source=blogpost&utm_medium=pr&utm_campaign=event&utm_content




阅读原文

跳转微信打开

Fish AI Reader

Fish AI Reader

AI辅助创作,多种专业模板,深度分析,高质量内容生成。从观点提取到深度思考,FishAI为您提供全方位的创作支持。新版本引入自定义参数,让您的创作更加个性化和精准。

FishAI

FishAI

鱼阅,AI 时代的下一个智能信息助手,助你摆脱信息焦虑

联系邮箱 441953276@qq.com

相关标签

Jetpack Navigation 3 Jetpack Compose Android导航
相关文章