前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >kotlin构建MVVM应用之依赖注入--Koin

kotlin构建MVVM应用之依赖注入--Koin

作者头像
大话swift
发布2020-04-16 11:49:41
1.5K0
发布2020-04-16 11:49:41
举报
文章被收录于专栏:大话swift大话swift

在开发的过程中,依赖注入有什么的好处呢?

  • 增加程序重用
  • 模块功能单一
  • 方便测试
  • 需求变更,减少程序开发
  • 充分的解耦合

Koin是一个Kotin极轻量的依赖注入框架,据官方资料显示,它有一下特点

  • 无代理
  • 无代码生成
  • 无反射。

在app\build.gradle中引入依赖

代码语言:javascript
复制
  1. //koin(依赖注入)
  2. implementation "org.koin:koin-androidx-scope:2.0.1"
  3. implementation "org.koin:koin-androidx-viewmodel:2.0.1"
  4. implementation "org.koin:koin-androidx-ext:2.0.1"

给大家展示一下整体的目录结构

首先,定义我们的model层,定义username和password两个被观察字段

代码语言:javascript
复制
  1. package com.xiangshike.live.model
  2. import androidx.databinding.ObservableField
  3. data class UserModel(
  4. var username: ObservableField<String> = ObservableField(""),
  5. var password: ObservableField<String> = ObservableField("")
  6. ) {
  7. override fun toString(): String {
  8. return "UserModel(username=
  9. }
  10. }

其次、定义我们的repository层返回我们需要的数据,当然了,你也可以通过网络请求获得数据

代码语言:javascript
复制
  1. package com.xiangshike.live.repository
  2. import androidx.databinding.ObservableField
  3. import com.xiangshike.live.model.UserModel
  4. class UserRepository {
  5. fun getUser(): UserModel = UserModel(ObservableField("hanyun"), ObservableField("123456"))
  6. }

再次、在我们viewmodel层把repository和model进行关联

代码语言:javascript
复制
  1. package com.xiangshike.live.viewmodel
  2. import androidx.lifecycle.ViewModel
  3. import com.xiangshike.live.model.UserModel
  4. import com.xiangshike.live.repository.UserRepository
  5. class UserViewModel(private val userRepository: UserRepository) : ViewModel() {
  6. fun getUser(): UserModel = userRepository.getUser()
  7. }

然后、在module中声明注入

代码语言:javascript
复制
  1. package com.xiangshike.live.di
  2. import com.xiangshike.live.repository.UserRepository
  3. import com.xiangshike.live.viewmodel.UserViewModel
  4. import org.koin.androidx.viewmodel.dsl.viewModel
  5. import org.koin.core.module.Module
  6. import org.koin.dsl.module
  7. val viewModelModule = module {
  8. viewModel {
  9. UserViewModel(get())
  10. }
  11. }
  12. val repositoryModule = module {
  13. factory<UserRepository> {
  14. UserRepository()
  15. }
  16. }
  17. val appModule: List<Module> = listOf(repositoryModule, viewModelModule)

再然后、声明引入我们的注入

代码语言:javascript
复制
  1. package com.xiangshike.live.di
  2. import com.xiangshike.live.repository.UserRepository
  3. import com.xiangshike.live.viewmodel.UserViewModel
  4. import org.koin.androidx.viewmodel.dsl.viewModel
  5. import org.koin.core.module.Module
  6. import org.koin.dsl.module
  7. val viewModelModule = module {
  8. viewModel {
  9. UserViewModel(get())
  10. }
  11. }
  12. val repositoryModule = module {
  13. factory<UserRepository> {
  14. UserRepository()
  15. }
  16. }
  17. val appModule: List<Module> = listOf(repositoryModule, viewModelModule)

这句为我们自动注入get()自动获得了UserRepository,然后实例化注入进来

代码语言:javascript
复制
  1. UserViewModel(get())

启用注入

代码语言:javascript
复制
  1. package com.xiangshike.live
  2. import android.app.Application
  3. import android.content.ContextWrapper
  4. import com.xiangshike.live.di.appModule
  5. import org.koin.core.context.startKoin
  6. lateinit var mApplication: Application
  7. class App : Application() {
  8. override fun onCreate() {
  9. super.onCreate()
  10. mApplication = this
  11. startKoin {
  12. modules(appModule)
  13. }
  14. }
  15. }
  16. object Application : ContextWrapper(mApplication)

表示启用注入

代码语言:javascript
复制
  1. startKoin {
  2. modules(appModule)
  3. }

使用

代码语言:javascript
复制
  1. class MainActivity : BaseActivity<ActivityMainBinding>() {
  2. private val mUserModel: UserModel by lazy { UserModel() }
  3. private val mUserViewModel: UserViewModel by viewModel()
  4. override fun getLayoutId(): Int = R.layout.activity_main
  5. override fun initData() {
  6. val user: UserModel = mUserViewModel.getUser()
  7. mUserModel.username = user.username
  8. mUserModel.password = user.password
  9. mDataBind.userModel = mUserModel
  10. }
  11. override fun initView() {
  12. loginBtn.setOnClickListener {
  13. login()
  14. }
  15. }
  16. ...
  17. }

我们通过下面这句,引入了我们UserViewModel

代码语言:javascript
复制
  1. private val mUserViewModel: UserViewModel by viewModel()

最终,我们应用启动的时候,给我们的用户和密码设置了默认值,同时实现了view和model的双向绑定。

链接:https://pan.baidu.com/s/1hUYyP7Uhb96LUV-CqgFp6g

提取码:ipcv

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-04-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 大话swift 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 首先,定义我们的model层,定义username和password两个被观察字段
  • 其次、定义我们的repository层返回我们需要的数据,当然了,你也可以通过网络请求获得数据
  • 再次、在我们viewmodel层把repository和model进行关联
  • 然后、在module中声明注入
  • 再然后、声明引入我们的注入
  • 启用注入
  • 使用
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档