5

让我先说一下,这更像是一个“结构性”问题,我并不是要求任何人编写代码。我只是想弄清楚我应该如何构建我的应用程序。

我正在为我的应用程序使用 Android 的DrawerLayout/ NavigationView。这意味着它MainActivity是我所有片段的宿主。

我目前有三个片段(实际上它更多,但它们或多或少与这三个片段完全一样,只是针对不同的数据集)。

  • 列表片段
  • 细节片段
  • EditFragment(用于添加和编辑)

在我的身上ListFragment,我有(惊喜!)一个物品清单。这是一个LiveData集合SharedViewModel(与MainActivity的生命周期相关联)。当一个项目被点击时,我通过MainActivity接口监听器传递事件。

MainActivity然后加载DetailFragment. 在同一个调用中,我加载了一个SharedViewModel(再次绑定到MainActivity)的实例。我设置SharedViewModel.selectedItem为被点击的项目。然后,在DetailFragment'sonCreate函数中,我通过ViewModelProviders.of(activity).get(SharedViewModel::class.java).selectedItem.

在 上DetailFragment,有一个编辑按钮。这或多或少地经历了上述相同的例程,但加载的是EditFragment相反的。保存编辑/添加的项目时,我通过的接口侦听器添加/替换SharedViewModel集合中的项目。MainActivity

显然,由于几个原因,这不是最优的。一方面,这意味着我至少有五组大型数据在MainActivity的生命周期中(本质上是应用程序的整个生命周期)。此外,MainActivity由于我必须添加越来越多的函数来处理事件,因此变得失控。

想要做的是,例如,我在 a 上的项目列表与ListFragmentViewModelListFragment生命周期相关联。我在 a 上选择的项目DetailFragmentViewModel,我在 an 上的编辑项目EditFragmentViewModel等。

我的问题是我不确定在这种情况下如何正确传递数据。例如,假设我在EditFragment. 我如何将它放入ListFragmentViewModel's 的项目集合中?ListFragment位于后台堆栈中,因此它的视图模型会挂起,并且在导航回时不会重新加载数据,因为它仍然具有之前的集合。这是有道理的,并且可能应该是这样(毕竟,谁愿意等待所有数据在DetailFragment返回和返回时加载ListFragment?),但这意味着我没有在集合中获得我的新项目。

这只是一个例子,但我遇到了很多类似的问题(例如,将所选项目传递给DetailFragmentViewModel.)

我不太确定我什至应该去哪里。有经验的人能帮帮我吗?

4

1 回答 1

4

假设我在 EditFragment 中添加了一个新项目。如何将其放入 ListFragmentViewModel 的项目集合中?

EditFragment告诉您的项目存储库,“哟!这是一个新项目!”。项目存储库安排更新您的后备存储,并向相关方发出事件通知数据更改(例如,在 RxJava 上发出事件PublishSubject)。ListFragmentViewModel监听这些事件并做出相应的反应。

ListFragment 在后台堆栈中,因此它的视图模型在导航回时挂起并且不会重新加载数据,因为它仍然具有之前的集合

它应该从您的项目存储库中找出数据更改,并做任何有意义的事情来反映该数据更改。这可能只是从数据更改事件中获取数据并更新其内存内容。这可能是从后备存储重新请求信息。原则上,它可能是别的东西。

于 2018-02-19T16:56:41.193 回答