在使用 Jetpack Compose Navigation 时,可以通过定义一个 NavType
来实现传递特定类型的数据。而如果数据类型是一个 data class,我们可以利用 companion Object 来实现对其实例的序列化和反序列化,从而作为参数传递给目标页面。
下面是解决问题的示例代码:
定义数据类:
data class User(val name: String, val age: Int) {
companion object {
fun fromBundle(bundle: Bundle): User {
return User(
bundle.getString("name") ?: "",
bundle.getInt("age")
)
}
fun toBundle(user: User): Bundle {
return Bundle().apply {
putString("name", user.name)
putInt("age", user.age)
}
}
}
}
在 User
类的 companion Object 中,我们定义了两个函数:fromBundle
和 toBundle
。前者用于将参数中的 Bundle 转换为一个 User 的实例,后者则将一个 User 实例转换为 Bundle。
定义 NavType:
val UserKeyType = object : NavType() {
override fun getName(): String = "user"
override fun getBundleValue(value: User): Bundle {
return User.toBundle(value)
}
override fun parseValue(bundle: Bundle): User {
return User.fromBundle(bundle)
}
}
在 UserKeyType
中,我们利用了 User.Companion.toBundle
和 User.Companion.fromBundle
这两个 companion Object 中定义的函数来实现序列化和反序列化。
通过 NavHost,我们可以将 UserKeyType
的实例与具体的参数结合起来:
NavHost(navController = navController, startDestination = "home") {
composable("home") {
HomeScreen(navController)
}
composable(
route = "user/{user}",
arguments = listOf(navArgument("user") { type = UserKeyType })
) { backStackEntry ->
UserScreen(backStackEntry.arguments?.getParcelable