详解Kotlin 中使用和配置 Dagger2

详解Kotlin 中使用和配置 Dagger2,第1张

概述前言陆陆续续几篇文章已经讲解了项目中Kotlin如何配置、简单语法、DataBinding配置,接下来就要说到Kotlin中的Dagger2了。

前言

陆陆续续几篇文章已经讲解了项目中 Kotlin 如何配置、简单语法、DataBinding 配置,接下来就要说到 Kotlin 中的 Dagger2 了。

配置 Dagger2

项目中使用 Dagger2 ,首先还是添加依赖。同样的,因为要使用到注解处理,所以和 DataBinding 一样要添加 kapt 插件:

 apply plugin: 'com.androID.application' ... apply plugin: 'kotlin-kapt' // kapt 插件 ... kapt {   generateStubs = true } dependencIEs {   ...   implementation 'com.Google.dagger:dagger:2.12' // Dagger 2 依赖   implementation 'com.Google.dagger:dagger-androID-support:2.12' // Dagger 2 AndroID 支持包   kapt 'com.Google.dagger:dagger-compiler:2.12' // Dagger 2 注解处理 }

配置很简单,就这样完成了。

使用 Dagger2

简单的配置完 Dagger2 ,接下来就是如何在 AndroID 项目中使用了。参见官方说明

首先使 Application 继承 DaggerApplication,Activity 继承 DaggerAppCompatActivity,Fragment 继承 DaggerFragment。

新建一个接口使用 @Subcomponent 注解继承 AndroIDInjector<YourActivity>,内部抽象类使用 @Subcomponent.Builder 注解继承AndroIDInjector.Builder<YourActivity>。

 @Subcomponent(modules = arrayOf(...)) // 没有其他 Module 圆括号可省略 interface YourActivitySub : AndroIDInjector<YourActivity> {   @Subcomponent.Builder   abstract class Builder : AndroIDInjector.Builder<YourActivity>() }

新建一个抽象类使用 @Module 注解,用于出入 Activity。

 @Module(subcomponents = arrayOf( YourActivitySub::class)) // 每新建一个 Activity,都要新建相应的 ActivitySub 接口,并添加到这里 abstract class ActivityModule {   @Binds // 每新建一个 Activity,都要添加一个相应方法,方法名不能相同   @IntoMap   @ActivityKey(YourActivity::class)   abstract fun bindYourActivity(builder: YourActivitySub.Builder): AndroIDInjector.Factory<out Activity>  } 

新建接口 YouApplicationSub 使用 @Component 注解,继承 AndroIDInjector<YourApplication>,内部抽象类使用 @Component.Builder 注解继承 AndroIDInjector.Builder<YourApplicaton>。

 @Singleton // 如果有 Module 使用了该注解实现单例模式,这里也需要添加 @Component(modules = arrayOf(   ActivityModule::class,// 注入 Activity 的 Module   FragmentModule::class,// 注入 Fragment 的 Module   ...   AndroIDSupportInjectionModule::class)) // 确保 DaggerApplication、DaggerActivity、DaggerFragment等所有类型可用 interface ApplicationSub : AndroIDInjector<MyApplication> {   @Component.Builder   abstract class Builder : AndroIDInjector.Builder<MyApplication>() }

使你的 Applicatoin 类继承 DaggerApplication。

 class MyApplication : DaggerApplication() { // 如果项目中使用了 v4.Fragment 要继承 support 包下的 DaggerApplication   overrIDe fun applicationInjector() : AndroIDInjector<out DaggerApplication> {     return DaggerApplicationSub.builder().create(this) // 编译后生成   } }

优化

这样使用是不是很麻烦?在 Dagger2 2.11 版本之前,项目中每添加一个 Activity 或 Fragment 等组件,都要新建一个对应 Subcomponent 接口,并添加到对应的 Module 中,并且添加相应的方法。这样使用起来太复杂了。

好在 Google 也同样的意识到了这个问题,所以在 Dagger2 2.11 版本及其以后,Dagger2 又为我们提供了一个 @ContributesAndroIDInjector 注解,大大的简化了使用。

首先,使用这个注解,你需要添加上 Dagger2 注解处理的 AndroID 支持:

 dependencIEs {   ...   implementation 'com.Google.dagger:dagger:2.12' // Dagger 2 支持    implementation 'com.Google.dagger:dagger-androID-support:2.12' // Dagger 2 AndroID 支持   kapt 'com.Google.dagger:dagger-compiler:2.12' // Dagger 2 注解处理   kapt 'com.Google.dagger:dagger-androID-processor:2.12' // Dagger 2 注解处理 AndroID 支持   ... }

然后,在注入 Activity 的 Module 中改变:

 @Module // 不需要再为每个 Activity 新建对应的 Subcomponent,不必再添加到这里 abstract class ActivityModule {   @ContributesAndroIDInjector   abstract fun contributeYourActivity() : YourActivity }

就这样,是不是简洁了很多?之后每添加一个 Activity,只需要在 Activity 添加一个对应的方法就可以了。

@ContributesAndroIDInjector 注解自动生成对应的 Subcomponent 而不需要我们手动添加。

语法解析

Dagger 2 的配置使用说完了,但是相信很多人对上面的一些语法都不了解,这里来简单说明:

 // Kotlin 提供的方法,能简单快速的生成一个数组 val array = arrayOf("1","2") // 与之类似的还有 arraylistof() 、 setof() 等,以后详细说明  // 类对象 A::class // 相当于 Java 中的 A.class,同时还有 A.javaClass 相当于 Java 中的 A.getClass()

最后

今天的 Kotlin Dagger2 使用就讲到这里,接下来我还会为大家带来更多的 Kotlin 相关语法知识以及基类封装等。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程小技巧。

总结

以上是内存溢出为你收集整理的详解Kotlin 中使用和配置 Dagger2全部内容,希望文章能够帮你解决详解Kotlin 中使用和配置 Dagger2所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1143962.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-31
下一篇 2022-05-31

发表评论

登录后才能评论

评论列表(0条)

保存