android - Dagger2 注入抽象 ViewModel 的特定实例
问题描述
我有一个 ViewModelFactory 实现如下:
class ViewModelFactory<VM> @Inject constructor(private val viewModel: Lazy<VM>)
: ViewModelProvider.Factory {
override fun <T : ViewModel?> create(modelClass: Class<T>): T {
@Suppress("UNCHECKED_CAST")
return viewModel.get() as T
}
}
这适用于我当前的 ViewModel:
class MainActivityViewModel @Inject constructor(private val dependency: Dependency) : ViewModel()
//... in the activity:
@Inject
lateinit var factory: ViewModelFactory<MainActivityViewModel>
private val viewModel: MainActivityViewModel by viewModels { factory }
但是我有不同的构建风格,我想在行为不同的地方实现,所以我创建了一个 AbstractViewModel:
abstract class AbstractViewModel : ViewModel()
//...and so now
class MainActivityViewModel @Inject constructor(private val dependency: Dependency) : AbstractViewModel()
//... and in the activity
@Inject
lateinit var factory: ViewModelFactory<AbstractViewModel>
private val viewModel: AbstractViewModel by viewModels { factory }
我希望能够为 ViewModelFactory 提供特定的实例,但我不确定如何实现这一点。
解决方案
解决了。回答以供将来参考和任何可能有兴趣做类似事情的人。
第 1 步:添加新的模块组件
@Component(
modules = [
//...
ViewModelModule::class
]
)
interface ApplicationComponent { //...
这允许开发人员创建一个FlavourApplicationComponent
可以替代 的ViewModelModule
,我称之为MockViewModelModule
第 2 步:定义模块
//in the main flavour
@Module
class ViewModelModule {
@Provides
fun provideMainActivityViewModel(mainActivityViewModel: MainActivityViewModel): AbstractViewModel
= mainActivityViewModel
}
//in the mock flavour
@Module
class MockViewModelModule {
@Provides
fun provideMainActivityViewModel(mainActivityViewModel: MainActivityViewModel): AbstractViewModel
= MockMainActivityViewModel()
}
这实际上可以在运行时进行配置,因此您可以允许用户测试应用程序的所有不同状态,而无需他们进入这些状态。
推荐阅读
- php - 带有 wordpress 的 Ajax 脚本在我的输出中添加了一个随机的“0”
- blazor - 在 blazor 中悬停时向元素添加类
- javascript - 使用 JS 如何在文档时间轴中获取动画结束值
- python - 从装饰函数将参数传递给装饰器
- templates - 如何在自动完成 vuetify 中过滤重复的模板项
- asp.net-mvc - 从模式 asp.net mvc 在 Html.DropdownListFor 上设置选定的值
- python - 如何在sql中将数字转换为日期
- javascript - 级联选择在 Reactjs React-hook-form 中不起作用
- c++ - 如何从字符串中删除某些内容
- angularjs - 为什么我的 mwl 日历不改变语言