您好,登錄后才能下訂單哦!
這篇文章主要介紹了Kotlin中如何使用和配置Dagger2,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
配置 Dagger2
項(xiàng)目中使用 Dagger2 ,首先還是添加依賴。同樣的,因?yàn)橐褂玫阶⒔馓幚?,所以?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 注解處理 }
配置很簡(jiǎn)單,就這樣完成了。
使用 Dagger2
簡(jiǎn)單的配置完 Dagger2 ,接下來就是如何在 Android 項(xiàng)目中使用了。參見官方說明
首先使 Application 繼承 DaggerApplication,Activity 繼承 DaggerAppCompatActivity,F(xiàn)ragment 繼承 DaggerFragment。
新建一個(gè)接口使用 @Subcomponent 注解繼承 AndroidInjector<YourActivity>,內(nèi)部抽象類使用 @Subcomponent.Builder 注解繼承AndroidInjector.Builder<YourActivity>。
@Subcomponent(modules = arrayOf(...)) // 沒有其他 Module 圓括號(hào)可省略 interface YourActivitySub : AndroidInjector<YourActivity> { @Subcomponent.Builder abstract class Builder : AndroidInjector.Builder<YourActivity>() }
新建一個(gè)抽象類使用 @Module 注解,用于出入 Activity。
@Module(subcomponents = arrayOf( YourActivitySub::class)) // 每新建一個(gè) Activity,都要新建相應(yīng)的 ActivitySub 接口,并添加到這里 abstract class ActivityModule { @Binds // 每新建一個(gè) Activity,都要添加一個(gè)相應(yīng)方法,方法名不能相同 @IntoMap @ActivityKey(YourActivity::class) abstract fun bindYourActivity(builder: YourActivitySub.Builder): AndroidInjector.Factory<out Activity> }
新建接口 YouApplicationSub 使用 @Component 注解,繼承 AndroidInjector<YourApplication>,內(nèi)部抽象類使用 @Component.Builder 注解繼承 AndroidInjector.Builder<YourApplicaton>。
@Singleton // 如果有 Module 使用了該注解實(shí)現(xiàn)單例模式,這里也需要添加 @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() { // 如果項(xiàng)目中使用了 v4.Fragment 要繼承 support 包下的 DaggerApplication override fun applicationInjector() : AndroidInjector<out DaggerApplication> { return DaggerApplicationSub.builder().create(this) // 編譯后生成 } }
優(yōu)化
這樣使用是不是很麻煩?在 Dagger2 2.11 版本之前,項(xiàng)目中每添加一個(gè) Activity 或 Fragment 等組件,都要新建一個(gè)對(duì)應(yīng) Subcomponent 接口,并添加到對(duì)應(yīng)的 Module 中,并且添加相應(yīng)的方法。這樣使用起來太復(fù)雜了。
好在 google 也同樣的意識(shí)到了這個(gè)問題,所以在 Dagger2 2.11 版本及其以后,Dagger2 又為我們提供了一個(gè) @ContributesAndroidInjector 注解,大大的簡(jiǎn)化了使用。
首先,使用這個(gè)注解,你需要添加上 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 // 不需要再為每個(gè) Activity 新建對(duì)應(yīng)的 Subcomponent,不必再添加到這里 abstract class ActivityModule { @ContributesAndroidInjector abstract fun contributeYourActivity() : YourActivity }
就這樣,是不是簡(jiǎn)潔了很多?之后每添加一個(gè) Activity,只需要在 Activity 添加一個(gè)對(duì)應(yīng)的方法就可以了。
@ContributesAndroidInjector 注解自動(dòng)生成對(duì)應(yīng)的 Subcomponent 而不需要我們手動(dòng)添加。
語法解析
Dagger 2 的配置使用說完了,但是相信很多人對(duì)上面的一些語法都不了解,這里來簡(jiǎn)單說明:
// Kotlin 提供的方法,能簡(jiǎn)單快速的生成一個(gè)數(shù)組 val array = arrayOf("1", "2") // 與之類似的還有 arrayListOf() 、 setOf() 等,以后詳細(xì)說明 // 類對(duì)象 A::class // 相當(dāng)于 Java 中的 A.class,同時(shí)還有 A.javaClass 相當(dāng)于 Java 中的 A.getClass()
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Kotlin中如何使用和配置Dagger2”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。