前言
网上都说Dagger2是比较难上手的,我在看了大量资料和使用时也遇到了很多不懂或者模糊的知识点,而且大部分博客资料都比较古老。突然有那么一瞬间,突然明白了所以然,故总结了4篇文章。话说在java中使用还是很繁琐的,不要怕带你真正上手,并运用到我们的Android项目中去。
本次Dagger2讲解总共分4篇:
1、Dagger2基础知识及在Java中使用(1)
2、Dagger2基础知识及在Java中使用(2)
3、Dagger2进阶知识及在Android中使用
4、Dagger2华丽使用在MVP框架中
通过前2篇文章的学习,已经熟悉Dagger2在Java中的使用了。但是你会发现,每次需要注入都要写对应的Component后,Inject到相关也面。而且在每个页面都要DaggerComponent.builder().build.inject(activity)。这样是太繁琐,还没开始,就觉得繁琐了。所以强大google推出了扩展包dagger.android。
还是老样子,博客贴的代码,有部分省略,只为便于理解。
Dagger2在Android中的使用
本篇就一节。只要配置好相关信息后,全局Component只有一个。Module你可以写多个,其实也可以只写2个,为什么呢,看下面。
首先是添加依赖,之前Java的依赖跟这里不相关哦
implementation 'com.google.dagger:dagger-android:2.24'
// if you use the support libraries(就是你需要v4.Fragment就需要加上support包)
implementation 'com.google.dagger:dagger-android-support:2.24'
annotationProcessor 'com.google.dagger:dagger-compiler:2.24'
annotationProcessor 'com.google.dagger:dagger-android-processor:2.24'
这里举2个例子把,一个带Module和一个不带Module的在Android中的使用,不带Module的小孩类Children如下,在其构造方法加上@Inject标注:
public class Children {
@Inject
public Children() {
}
}
然后是带Module的超人类SurperMan,假设是一个第三方类库,不能带@Inject标注。
public class SurperMan {
}
我们此时的Module
@Module
public class SurperManModule {
@Provides
SurperMan surperManProvides(){
return new SurperMan();
}
}
这个时候dagger.android包提供了一个@ContributesAndroidInjector标注是为了省去我们每次去Activity里初始化Component,如下
@Module
//抽象类,名字自定义,
public abstract class NeedInjectModules {
//这个方法的意思标识要注入到ForAndroidActivity页面。如果需要在MainActivity页面的话。继续加这个方法,返回值为
//MainActivity即可
@ContributesAndroidInjector
abstract ForAndroidActivity inject();
}
之前就提过,在dagger.android包里。大概思路是在Application初始化ApplicationComponent,然后我们通过@ContributesAndroidInjector标注,他内部帮我实现了Component依赖Component。那么我们的唯一个Component长这样
//这里AndroidSupportInjectionModule是系统的,必须加上
//NeedInjectModules是我们要注册到Activity的
//SurperManModule,surperMan的
@Component(modules = {
AndroidSupportInjectionModule.class,
NeedInjectModules.class,
SurperManModule
})
//继承AndroidInjector<T>,泛型就是我们的application
public interface AppComponent extends AndroidInjector<MyApplication> {
//还记得@Component.Builder的用法吗,可以看之前的。
@Component.Builder
interface Builder {
@BindsInstance
Builder application(Application application);
AppComponent build();
}
}
这些准备工作都做完了后,记得Make Project,接下来是重点了,我们的Application继承DaggerApplication,这里会实现一个方法,是将我们的AppComponent.Builder返回出去,如下
public class MyApplication extends DaggerApplication {
@Override
protected AndroidInjector<? extends DaggerApplication> applicationInjector() {
return DaggerAppComponent.builder().application(MyApplication.this).build();
}
}
这里也是关键点,在Activity里使用或者在Fragment里使用,只需继承我们的DaggerActivity&DaggerFragment。直接看我们的Activity
public class ForAndroidActivity extends DaggerAppCompatActivity {
@Inject
Children children;
@Inject
SurperMan surperMan;
@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_astudy);
LogUtils.i("已经生成实例",children.hashCode()+"");
LogUtils.i("已经生成实例",surperMan.hashCode()+"");
}
}
至此,在Android中的简单使用,已经全部介绍完,是不是代码比较简洁。是不是已经爱不释手了!
本文github Demo地址
花了老大劲,别误会,不是要钱。能不能留下个足迹star啊