文章预览
在上一篇博客中我尝试解释了 dagger-android
注入。收到了一些评论,有的人说太复杂了没必要
为了使用新特性去升级。我想到会发生这种情况,但我还是觉得有必要去解释dagger在幕后所做的工作。在阅读这篇博客之前
我强烈建议先阅读第一篇博客。本文中我会使用 **_@ContributesAndroidInjector_**
注解来简化上篇博客中的代码。
我们通过下面的图片来回忆第一篇博客中 dagger
结构图。
我们一步步来检查该图谱。我只介绍 MainActivity
这部分。其他部分的逻辑一样。
- 创建一个
_AppComponent_
和 _AppModule_
。
- 创建
_MainActivity_
, _MainActivityComponent_
, _MainActivityModule_
。
- 映射
_MainActivity_
到 _ActivityBuilder_
(这样 dagger
就能够知道 MainActivity
将被注入)。
让我们开始吧。在 _MainActivity_
中调用 **_AndroidInjection.inject(this)_**
并且在 _MainActivityModule_
中添加生成实例的方法。
我们只是想注入到 MainActivity
,却做了很多事情。能不能进一步简化?怎么简化?
@Subcomponent
注解的 MainActivityComponent
和 DetailActivityComponent
在图中只是起到类似桥梁的作用。我们能够很容易地写出这两个类。
- 每当我们添加
UI
组件作为新的 subcomponent
都必须把 activity
映射到 ActivityBuilder module
。这个工作经常是重复的。
不要做重复性的工作
dagger
的作者们显然也意识到这个问题,给了一个新的解决方法。于是就有了这个新注解—— **@ContributesAndroidInjector .**
,使用这个注解我们能够轻松地把 activities/fragments
添加到 dagger
结构中。下图为简化后的 dagger
结构图,代码稍后给出。
通过上面的结构图我想你们能够理解得更深。这里给出修改后的代码。
当然也可以从 android injection
分支中拉取代码。
掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 Android、iOS、前端、后端、区块链、产品、设计、人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划、官方微博、知乎专栏。
………………………………