JetPack文章相关目录
相关文章:
Jetpack:LifeCycle全面解析(包含检测app启动、进入前台、进入后台例子)。
Jetpack:ViewModel使用指南,实现原理详细解析!
Jetpack:LiveData使用指南,实现原理详细解析!
Jetpack:Room超详细使用踩坑指南!
Jetpack:Room数据库升级详解实战!
文章目录
- JetPack文章相关目录
- 简介
- DataBinding简单使用
- DataBinding响应事件
- DataBinding二级页面的绑定
- BindAdapter简单原理分析
- 自定义BindAdapter
- 实现双向绑定
- 自定义InverseBindingAdapter
- InverseBindingAdapter简单分析
- 总结
简介
DataBinding可以让布局承担部分原本属于页面的工作,可以使得页面与布局文件之间的耦合程度降低。
DataBinding具有以下几点优势:
- 部分与UI相关的代码可在布局中完成,代码更简洁,可读。
- 不需要使用findViewById()方法。
- 布局文件可以包含简单的业务逻辑。
依赖:需要在模块的 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
选项,由编译器帮忙进行转化。如下图所示:
修改完成后的布局如下所示:<?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
类。
举个