您好,登錄后才能下訂單哦!
這篇文章主要介紹了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”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。