這篇文章主要介紹了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,F(xiàn)ragment 繼承 DaggerFragment。
新建一個接口使用 @Subcomponent 注解繼承 AndroidInjector<YourActivity>,內(nèi)部抽象類使用 @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,都要新建相應(yīng)的 ActivitySub 接口,并添加到這里
abstract class ActivityModule {
@Binds // 每新建一個 Activity,都要添加一個相應(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 使用了該注解實現(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() { // 如果項目中使用了 v4.Fragment 要繼承 support 包下的 DaggerApplication
override fun applicationInjector() : AndroidInjector<out DaggerApplication> {
return DaggerApplicationSub.builder().create(this) // 編譯后生成
}
}優(yōu)化
這樣使用是不是很麻煩?在 Dagger2 2.11 版本之前,項目中每添加一個 Activity 或 Fragment 等組件,都要新建一個對應(yīng) Subcomponent 接口,并添加到對應(yīng)的 Module 中,并且添加相應(yīng)的方法。這樣使用起來太復(fù)雜了。
好在 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 新建對應(yīng)的 Subcomponent,不必再添加到這里
abstract class ActivityModule {
@ContributesAndroidInjector
abstract fun contributeYourActivity() : YourActivity
}就這樣,是不是簡潔了很多?之后每添加一個 Activity,只需要在 Activity 添加一個對應(yīng)的方法就可以了。
@ContributesAndroidInjector 注解自動生成對應(yīng)的 Subcomponent 而不需要我們手動添加。
語法解析
Dagger 2 的配置使用說完了,但是相信很多人對上面的一些語法都不了解,這里來簡單說明:
// Kotlin 提供的方法,能簡單快速的生成一個數(shù)組
val array = arrayOf("1", "2") // 與之類似的還有 arrayListOf() 、 setOf() 等,以后詳細(xì)說明
// 類對象
A::class // 相當(dāng)于 Java 中的 A.class,同時還有 A.javaClass 相當(dāng)于 Java 中的 A.getClass()感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Kotlin中如何使用和配置Dagger2”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
標(biāo)題名稱:Kotlin中如何使用和配置Dagger2-創(chuàng)新互聯(lián)
文章鏈接:http://www.chinadenli.net/article34/deiese.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作、網(wǎng)站維護、網(wǎng)站排名、ChatGPT、軟件開發(fā)、移動網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)