【发布时间】:2020-08-07 07:40:51
【问题描述】:
我有一个场景,其中两个片段(A 和 B)需要共享一个对象列表,这些对象可以从两个屏幕上进行变异。 A 和 B 片段各有一个对应的 ViewModel(A_ViewModel 和 B_ViewModel)。它们包含一些关于如何改变共享数据的逻辑。
为了保持共享数据的完整性,我创建了 AB_Flow_ViewModel,它是活动范围的,包含包装在 MutableLiveData 中的共享数据。
我决定将 MutableLiveData 对象作为构造函数参数传递给 A 和 B 子片段。
我从未在任何地方看到过这种方法,但它似乎对我来说非常有效。
这样做有什么缺点吗?
这是我的解决方案的伪代码:
// Navigation: (A -> B)
class A() : Fragment() {
private val viewModel: A_ViewModel ...
override fun onViewCreated(
view: View,
savedInstanceState: Bundle?
) {
super.onViewCreated(view, savedInstanceState)
viewModel.sharedData.observe {
...
}
}
}
class A_ViewModel @Inject constructor(
val sharedData: MutableLiveData<List<Any>>
) : ViewModel() {
fun changeSharedData(newSharedData: List<Any>) {
sharedData.value = newSharedData
}
}
@Module
class A_Module {
@Provides
@FragmentScoped
fun provideSharedData(fragment: A) =
fragment.activityViewModels<AB_Flow_ViewModel>().value.sharedData
}
class B() : Fragment() {
private val viewModel: A_ViewModel ...
override fun onViewCreated(
view: View,
savedInstanceState: Bundle?
) {
super.onViewCreated(view, savedInstanceState)
viewModel.sharedData.observe {
...
}
}
}
@Module
class B_Module {
@Provides
@FragmentScoped
fun provideSharedData(fragment: B) =
fragment.activityViewModels<AB_Flow_ViewModel>().value.sharedData
}
class B_ViewModel @Inject constructor(
val sharedData: MutableLiveData<List<Any>>
) : ViewModel() {
fun changeSharedData(newSharedData: List<Any>) {
sharedData.value = newSharedData
}
}
class AB_Flow_ViewModel() : ViewModel() {
val sharedData = MutableLiveData<List<Any>>()
}
【问题讨论】:
标签: android mvvm viewmodel android-livedata