首页
/ Compose Destinations 中共享 ViewModel 的正确实现方式

Compose Destinations 中共享 ViewModel 的正确实现方式

2025-06-25 08:21:44作者:董宙帆

问题背景

在使用 Compose Destinations 导航库时,开发者经常需要在多个屏幕间共享 ViewModel。官方文档提供了一个标准实现模式,但实际应用中可能会遇到序列化异常问题。

核心问题分析

当按照官方文档示例实现时,会出现 SerializationException 异常,提示无法找到 SettingsGraph 的序列化器。这是因为在获取导航栈条目时,直接传入了导航图对象而非其路由字符串。

解决方案

正确的实现方式是在获取导航栈条目时使用导航图的 route 属性:

navGraph(NavGraphs.settings) {
    val parentEntry = remember(navBackStackEntry) {
        navController.getBackStackEntry(NavGraphs.settings.route)
    }
    dependency(hiltViewModel<SettingsViewModel>(parentEntry))
}

技术原理

  1. 导航图序列化问题:Compose Destinations 生成的导航图对象本身不可序列化,但其 route 属性是字符串类型,可以直接用于导航栈查询。

  2. ViewModel 作用域:通过这种方式创建的 ViewModel 会被绑定到指定的导航图作用域,该导航图下的所有目的地都能访问同一个 ViewModel 实例。

  3. 生命周期管理:ViewModel 的生命周期将与导航图保持一致,当用户离开该导航图时,ViewModel 会被自动清理。

最佳实践建议

  1. 对于共享 ViewModel 的场景,建议使用 Hilt 进行依赖注入,确保依赖关系清晰。

  2. 在大型项目中,可以考虑为每个功能模块创建独立的导航图,并在模块内部共享 ViewModel。

  3. 注意 ViewModel 的初始化时机,避免在导航图还未创建时就尝试访问 ViewModel。

总结

Compose Destinations 提供了强大的导航和依赖管理能力,但在实际应用中需要注意一些实现细节。通过正确使用导航图的 route 属性,可以避免序列化问题,实现跨屏幕的 ViewModel 共享。这种模式特别适合设置页面、用户配置等需要跨多个屏幕共享状态的场景。

登录后查看全文
热门项目推荐
相关项目推荐