13、在 Compose 中使用 Jetpack Navigation 实现导航

在 Compose 中使用 Jetpack Navigation 实现导航

在 Android 应用开发中,导航功能是提升用户体验的重要部分。本文将详细介绍如何在 Compose 中使用 Jetpack Navigation 实现屏幕间的导航,以及如何添加深度链接支持。

1. 获取餐厅数据

为了避免从远程 Firebase API 获取餐厅对象时阻塞主线程,我们需要启动一个协程。使用 viewModelScope 协程构建器,确保协程的生命周期与 RestaurantDetailsViewModel 实例一致。在协程内部,我们执行以下操作:
1. 调用 getRemoteRestaurants() 挂起函数,并传入硬编码的餐厅 ID 值 2。此时, RestaurantsViewModel 还不知道要查找的餐厅 ID,后续进行导航时会解决这个问题。
2. 将获取的餐厅对象存储在 restaurant 变量中,并将其传递给 RestaurantDetailsViewModel 类的状态变量,以便 UI 能够根据最新的餐厅内容进行重组。

viewModelScope.launch {
    val restaurant = getRemoteRestaurants(2)
    state.value = restaurant
}
2. 构建餐厅详情屏幕

接下来,

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值