Cách Triển Khai Hilt Dagger Trong Dự Án Android Kotlin
Hilt là một thư viện Dependency Injection (DI) của Google được xây dựng trên Dagger, giúp đơn giản hóa việc sử dụng DI trong ứng dụng Android. Trong bài viết này, chúng ta sẽ cùng tìm hiểu về cách triển khai Hilt trong một dự án Android, từ cài đặt đến áp dụng thực tế.
1. Tại Sao Lại Sử Dụng Hilt?
Trước khi đi vào chi tiết về cách triển khai Hilt, hãy cùng xem qua một số lý do tại sao chúng ta nên sử dụng Hilt trong các dự án Android:
- Đơn giản hóa DI: Hilt giúp việc cấu hình và sử dụng DI trở nên đơn giản hơn rất nhiều so với việc sử dụng Dagger thuần túy.
- Tích hợp sâu với Android: Hilt cung cấp các annotation đặc biệt cho các thành phần Android như Activity, Fragment, ViewModel, giúp việc tiêm phụ thuộc dễ dàng và trực quan hơn.
- Lifecycle-aware: Hilt tích hợp với lifecycle của Android, giúp quản lý vòng đời của các dependency một cách hiệu quả.
2. Cài Đặt Hilt
Để bắt đầu sử dụng Hilt trong dự án Android, bạn cần thực hiện một số bước cài đặt cơ bản:
- Thêm các dependency cần thiết vào tệp build.gradle của project:
buildscript {
ext.hilt_version = '2.42'
dependencies {
classpath "com.google.dagger:hilt-android-gradle-plugin:$hilt_version"
}
}
allprojects {
repositories {
google()
mavenCentral()
}
}
- Thêm plugin và dependency vào tệp build.gradle của module:
plugins {
id 'com.android.application'
id 'kotlin-android'
id 'kotlin-kapt'
id 'dagger.hilt.android.plugin'
}
dependencies {
implementation "com.google.dagger:hilt-android:$hilt_version"
kapt "com.google.dagger:hilt-android-compiler:$hilt_version"
}
- Kích hoạt Hilt trong ứng dụng:
@HiltAndroidApp
class MyApplication : Application() {
}
3. Triển Khai Hilt Trong Các Thành Phần Android
- Activity và Fragment:
- Activity:
@AndroidEntryPoint
class MainActivity : AppCompatActivity() {
@Inject lateinit var myDependency: MyDependency
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
// Sử dụng myDependency
}
}
- Fragment:
@AndroidEntryPoint
class MyFragment : Fragment() {
@Inject lateinit var myDependency: MyDependency
override fun onCreateView(
inflater: LayoutInflater, container: ViewGroup?,
savedInstanceState: Bundle?
): View? {
// Sử dụng myDependency
return inflater.inflate(R.layout.fragment_my, container, false)
}
}
- ViewModel
- Tạo ViewModel với Hilt:
@HiltViewModel
class MyViewModel @Inject constructor(
private val myRepository: MyRepository
) : ViewModel() {
// Logic của ViewModel
}
- Sử dụng ViewModel trong Activity hoặc Fragment:
@AndroidEntryPoint
class MyActivity : AppCompatActivity() {
private val viewModel: MyViewModel by viewModels()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_my)
// Sử dụng viewModel
}
}
4. Tạo Module Hilt
Modules trong Hilt được sử dụng để cung cấp các dependency. Bạn có thể tạo một module để cung cấp các dependency cần thiết cho ứng dụng:
@Module
@InstallIn(SingletonComponent::class)
object AppModule {
@Provides
@Singleton
fun provideMyRepository(apiService: ApiService): MyRepository {
return MyRepositoryImpl(apiService)
}
@Provides
@Singleton
fun provideApiService(): ApiService {
return Retrofit.Builder()
.baseUrl("https://api.example.com")
.addConverterFactory(GsonConverterFactory.create())
.build()
.create(ApiService::class.java)
}
}
5. Kết Luận
Hilt là một công cụ mạnh mẽ giúp đơn giản hóa việc quản lý Dependency Injection trong các dự án Android. Việc triển khai Hilt không chỉ giúp mã nguồn trở nên gọn gàng và dễ hiểu hơn, mà còn giúp bạn dễ dàng mở rộng và bảo trì ứng dụng trong tương lai. Hy vọng qua bài viết này, bạn đã nắm được những bước cơ bản để triển khai Hilt trong dự án của mình.
All Rights Reserved