我写了一篇关于这个问题的文章,详细介绍了如何使用Dagger2实现模块化架构:
《Dagger2 for Modular Architecture》,但以下是简单回答。
你需要以不同的方式使用Dagger2。与其为每个功能模块使用一个module或subcomponent,你需要使用一个带有依赖于基础AppComponent的component。
在一个单独的模块中,我们通常会做如下操作:
@Singleton
@Component(modules = arrayOf(NetworkModule::class, RepositoryModule::class,
SubcomponentModule::class))
interface ApplicationComponent : AndroidInjector<MyApplication> {
val userRepository: UserRepository
val apiService: ApiService
}
@Module
object NetworkModule {
@Provides
@Singleton
@JvmStatic
fun provideApiService(okHttp: OkHttp): ApiService {
return ApiSerive(okHttp)
}
}
但正如你所说,你无法访问可能在另一个模块中或引用其他功能模块中的dagger子组件模块。
你只需要在依赖于ApplicationComponent的特性模块中创建一个新的dagger模块,就像这样:
@Browser
@Component(modules = [(BrowserModule::class)],
dependencies = [(AppComponent::class)])
interface BrowserComponent : AndroidInjector<AppCompatActivity> {
@Component.Builder
abstract class Builder: AndroidInjector.Builder<AppCompatActivity>(){
abstract fun plus(component: AppComponent): Builder
}
}
相应的特征活动将构建该组件:
class BrowserActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
DaggerBrowserComponent
.builder()
.plus((application as MyApplication).component)
.build()
.inject(this)
}
}