Jetpack:DataBinding超详细指南-Kotlin版!

JetPack文章相关目录

相关文章:
Jetpack:LifeCycle全面解析(包含检测app启动、进入前台、进入后台例子)。
Jetpack:ViewModel使用指南,实现原理详细解析!
Jetpack:LiveData使用指南,实现原理详细解析!
Jetpack:Room超详细使用踩坑指南!
Jetpack:Room数据库升级详解实战!

文章目录


简介

DataBinding可以让布局承担部分原本属于页面的工作,可以使得页面与布局文件之间的耦合程度降低。

DataBinding具有以下几点优势:

  1. 部分与UI相关的代码可在布局中完成,代码更简洁,可读。
  2. 不需要使用findViewById()方法。
  3. 布局文件可以包含简单的业务逻辑。

依赖:需要在模块的 build.gradle 文件中将 dataBinding 构建选项设置为 true,如下所示:

android {
    ...
    buildFeatures {
        dataBinding true
    }
}
//开启kapt
plugins {
    ...
    id 'kotlin-kapt'
}

注意

可以同时使用viewBinding和dataBinding,布局里面使用layout标签,则生成ViewDataBinding类型,否则生成ViewBinding类型的绑定类

DataBinding简单使用

  • 根据简介的描述在build.gradle开启dataBinding

  • 修改布局文件
    在布局文件最外层添加<layout>标签作为根节点。可以手动修改添加<layout>标签;也可以将鼠标移动到原布局跟节点位置,单击浮现的灯泡按钮,然后选择Convert to databinding layout选项,由编译器帮忙进行转化。如下图所示:
    Jetpack:DataBinding超详细指南-Kotlin版!
    修改完成后的布局如下所示:

    <?xml version="1.0" encoding="utf-8"?>
    <layout xmlns:android="http://schemas.android.com/apk/res/android">
        <androidx.constraintlayout.widget.ConstraintLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent">
        </androidx.constraintlayout.widget.ConstraintLayout>
    </layout>
    
  • 实例化布局文件
    常规的实例化布局文件方法通过Activity.this.setContentView()方法实例布局文件,然后通过findViewById()方法找到对应的UI控件并使用。使用DataBinding之后可以直接获取对应的Binding类,然后将跟布局设置进布局文件即可;或者使用DataBindingUtil.setContentView()方法直接设置布局文件,且该方法也会返回对应的Binding
    举个

上一篇:Android-DataBinding-从入门到进阶,附带学习经验


下一篇:Android--Material Design