Kotlin jetpack MVP

开启dataBinding

app build.gradle

复制代码
android {
	buildFeatures {
        dataBinding true
    }
}
  • 一些依赖库

    复制代码
      def lifecycle_version = "2.4.1"
      // https://developer.android.google.cn/jetpack/androidx/releases/lifecycle?hl=en
      // LiveData
      api "androidx.lifecycle:lifecycle-livedata-ktx:$lifecycle_version"
      // ViewModel
      api "androidx.lifecycle:lifecycle-viewmodel-ktx:$lifecycle_version"
      // optional - ProcessLifecycleOwner provides a lifecycle for the whole application process
      api "androidx.lifecycle:lifecycle-process:$lifecycle_version"
      // Lifecycles only (without ViewModel or LiveData)
      api "androidx.lifecycle:lifecycle-runtime-ktx:$lifecycle_version"
      // 在Activity中使用viewModels
      api "androidx.activity:activity-ktx:1.3.1"
      // 在Fragment中使用viewModels
      api "androidx.fragment:fragment-ktx:1.3.6"

基类

复制代码
abstract class BaseActivity<VDB : ViewDataBinding>(private var contentViewID:Int){
	protected lateinit var binding: VDB

	@CallSuper
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        binding = DataBindingUtil.setContentView(this, contentViewID)
    }
}

子类

复制代码
class MainActivity : BaseActivity<ActivityMainBinding>(R.layout.activity_main){

    private val xVM: XxxxVM by viewModels()
    // 发起任务
  	xVM.getXx(xId)
	// 处理结果
	xVM.xLiveData.observe(this) { bid ->
    }
}

xml布局

复制代码
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools">

    <data>

    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <FrameLayout
            android:id="@+id/container"
            android:layout_width="match_parent"
            android:layout_height="0dp"
            android:layout_weight="1" />

        <include
            android:id="@+id/tabLayout"
            layout="@layout/tab_main_activity" />

    </LinearLayout>
</layout>

处理任务的ViewMode

复制代码
class BindBrandVM : ViewModel() {
    val xLiveData = MutableLiveData<String>()

    fun getXx(x: String) {
        RetrofitManager.api.xxxxx(FormBody.Builder()
            .add("xxx", x)
            .build())
            .subscribeOn(Schedulers.io())
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(object : BaseSubscriber<BaseHttpEntity<XxxxRes>>() {
                override fun onErr(throwable: Throwable) {}
                override fun onNext(res: BaseHttpEntity<XxxxRes>) {
                    super.onNext(res)
                    try {
                        if (res.result != null) {
                            val bid = res.result!!.bid
                            xLiveData.value = bid
                        }
                    } catch (e: java.lang.Exception) {
                    }
                }
            })
    }
}

还可以添加其他jetpack库。。。。。。。。。。。

相关推荐
游戏开发爱好者842 分钟前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview
王码码20351 小时前
Flutter for OpenHarmony 实战之基础组件:第三十一篇 Chip 系列组件 — 灵活的标签化交互
android·flutter·交互·harmonyos
黑码哥1 小时前
ViewHolder设计模式深度剖析:iOS开发者掌握Android列表性能优化的实战指南
android·ios·性能优化·跨平台开发·viewholder
亓才孓1 小时前
[JDBC]元数据
android
独行soc1 小时前
2026年渗透测试面试题总结-17(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
金融RPA机器人丨实在智能2 小时前
Android Studio开发App项目进入AI深水区:实在智能Agent引领无代码交互革命
android·人工智能·ai·android studio
科技块儿2 小时前
利用IP查询在智慧城市交通信号系统中的应用探索
android·tcp/ip·智慧城市
独行soc2 小时前
2026年渗透测试面试题总结-18(题目+回答)
android·网络·安全·web安全·渗透测试·安全狮
王码码20353 小时前
Flutter for OpenHarmony 实战之基础组件:第二十七篇 BottomSheet — 动态底部弹窗与底部栏菜单
android·flutter·harmonyos
2501_915106323 小时前
app 上架过程,安装包准备、证书与描述文件管理、安装测试、上传
android·ios·小程序·https·uni-app·iphone·webview