数据绑定库 Android Jetpack 的一部分。
数据绑定库是一个支持库,可让您使用声明性格式(而不是以程序化方式)将布局中的界面组件绑定到应用中的数据源。
布局通常使用调用界面框架方法的代码在 activity 中定义。例如,以下代码会调用 findViewById()
来查找 TextView
widget 并将其绑定到 viewModel
变量的 userName
属性:
Kotlin
findViewById<TextView>(R.id.sample_text).apply { text = viewModel.userName }
Java
TextView textView = findViewById(R.id.sample_text); textView.setText(viewModel.getUserName());
以下示例展示了如何使用数据绑定库直接在布局文件中将文本分配给 widget。这样便无需调用上述任何 Java 代码。请注意在赋值表达式中使用 @{}
语法:
<TextView
android:text="@{viewmodel.userName}" />
通过布局文件中的绑定组件,您可以移除 activity 中的许多界面框架调用,使其更易于维护。这还可以提高应用的性能,并帮助防止内存泄漏和 null 指针异常。
使用数据绑定库
请参阅以下页面,了解如何在 Android 应用中使用数据绑定库。
- 使用入门
- 了解如何准备开发环境以使用数据绑定库,包括支持 Android Studio 中的数据绑定代码。
通过表达式语言,您可以编写表达式,将变量连接到布局中的视图。数据绑定库会自动生成将布局中的视图与您的数据对象绑定所需的类。该库提供了可在布局中使用的导入、变量和 include 等功能。
该库的这些功能可与您的现有布局无缝共存。例如,可以在表达式中使用的绑定变量是在 data
元素内定义的,该元素是界面布局根元素的同级。这两个元素都封装在 layout
标记中,如以下示例所示:
<layout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<data>
<variable
name="viewmodel"
type="com.myapp.data.ViewModel" />
</data>
<ConstraintLayout... /> <!-- UI layout's root element -->
</layout>
- 使用可观察的数据对象
- 数据绑定库提供了用于轻松观察数据变化的类和方法。您无需担心在底层数据源发生更改时刷新界面。您可以将变量或其属性设为可观察。借助该库,您可以将对象、字段或集合设为可观察。
- 生成的绑定类
- 数据绑定库可以生成用于访问布局变量和视图的绑定类。本页介绍了如何使用和自定义生成的绑定类。
- 绑定适配器
- 对于每个布局表达式,都有一个绑定适配器,可进行框架调用以设置相应的属性或监听器。例如,绑定适配器可以负责调用
setText()
方法来设置文本属性,或调用setOnClickListener()
方法将监听器添加到点击事件。您可以在android.databinding.adapters
软件包中使用最常见的绑定适配器(例如本页的示例中使用的android:text
属性的适配器)。如需查看常见绑定适配器的列表,请参阅适配器。您还可以创建自定义适配器,如以下示例所示 :
Kotlin
@BindingAdapter("app:goneUnless") fun goneUnless(view: View, visible: Boolean) { view.visibility = if (visible) View.VISIBLE else View.GONE }
Java
@BindingAdapter("app:goneUnless") public static void goneUnless(View view, Boolean visible) { view.visibility = visible ? View.VISIBLE : View.GONE; }
- 将布局视图绑定到架构组件
- Android 支持库包含架构组件,您可以使用这些组件设计稳健、可测试且可维护的应用。您可以将架构组件与数据绑定库一起使用,以进一步简化界面的开发。
- 双向数据绑定
- 数据绑定库支持双向数据绑定。用于此类绑定的表示法支持接收属性的数据更改,并同时监听用户对该属性的更新。
其他资源
如需详细了解数据绑定,请参阅下面列出的其他资源。
示例
Codelab
博文
为您推荐
- 注意:当 JavaScript 处于关闭状态时,系统会显示链接文字
- 绑定适配器 {:#binding-adapters}
- 布局和绑定表达式
- 生成的绑定类 {: #binding-classes}