classpath ‘com.google.dagger:hilt-android-gradle-plugin:2.28-alpha’
Hilt 需要 AndroidManifest
使用带有 @HiltAndroidApp
注解的 Application 类,所以我们的 Application需要这样:
@HiltAndroidApp
class HiltApp : Application() {
…
}
然后在 AndroidManifest 文件中声明:
<application
android:name=".HiltApp"
…
假如我们要在 MainActivity
中注入一个 User
对象, 我们首先编写一个 User 类,User类有两个属性 name
和 age
。
诶,这个时候有同学就会问了:我通过 @Inject
声明一个User,Hilt就能给我创建一个 User 对象,那这个User对象里面的name和age是啥?答案是:编译会报错,因为我们自己都不知道这两个参数是啥,Hilt怎么可能会知道,所以这两个属性也要通过依赖注入的方式来注入。
为了简化这个问题,我定义一个默认的无参构造函数,反正创建之后,里面的值也是可以修改的嘛。
data class User(var name: String, var age: Int) {
// 定义一个默认的无参构造函数,并使用 @Inject 注解修饰
@Inject
constructor() : this(“Rikka”, 23)
}
接着我们在 MainActivity
中声明一个 User,通过 @Inject
来修饰,并且MainActivity 需要通过 @AndroidEntryPoint
修饰:
// 1
@AndroidEntryPoint
class MainActivity : AppCompatActivity() {
// 2
@Inject
lateinit var user: User
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
Log.d(TAG, “user name: u s e r . n a m e a g e : {user.name} age: user.nameage:{user.age}”)
}
}
Logcat 打印结果如下:
代码解析:
注释1: 为 MainActivity 修饰 @AndroidEntryPoint
,该注解表明 该类为需要进行依赖注入的 Android类,是Dagger针对Android场景化的地方。当我们类中需要进行依赖注入,我们为该类加入这个注解,它会帮助创建一个单独的 Hilt组件。它不能修饰Abstract,它只能修饰:
-
ComponentActivity
-
(Support)F