国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > Android > 正文

詳解Kotlin 中使用和配置 Dagger2

2019-12-12 01:47:36
字體:
來源:轉載
供稿:網友

前言

陸陸續續幾篇文章已經講解了項目中 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 相關語法知識以及基類封裝等。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 合肥市| 醴陵市| 宜兰县| 长白| 韶关市| 同德县| 沈阳市| 垦利县| 武隆县| 泽州县| 临海市| 包头市| 天长市| 长子县| 印江| 休宁县| 石景山区| 恭城| 江城| 襄垣县| 枣阳市| 福建省| 杭锦后旗| 洞口县| 呼图壁县| 密山市| 竹山县| 阳信县| 五河县| 新河县| 白城市| 绥化市| 旬阳县| 固始县| 上栗县| 台湾省| 南昌市| 邛崃市| 陆丰市| 德州市| 福贡县|