数据绑定库 属于 Android Jetpack 的一部分。
数据绑定库是一个支持库,允许您使用声明性格式而不是编程方式将布局中的 UI 组件绑定到应用中的数据源。
布局通常在活动中定义,其中包含调用 UI 框架方法的代码。例如,以下代码调用 findViewById()
来查找 TextView
小部件并将其绑定到 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());
以下示例展示了如何使用数据绑定库直接在布局文件中将文本分配给小部件。这消除了调用上述任何 Java 代码的必要性。请注意在赋值表达式中使用了 @{}
语法
<TextView
android:text="@{viewmodel.userName}" />
在布局文件中绑定组件使您能够在活动中删除许多 UI 框架调用,从而使活动更简单、更易于维护。这也能够提高应用的性能,并有助于防止内存泄漏和空指针异常。
使用数据绑定库
使用以下页面了解如何在 Android 应用中使用数据绑定库。
- 入门
- 了解如何准备好开发环境以使用数据绑定库,包括在 Android Studio 中支持数据绑定代码。
表达式语言允许您编写将变量连接到布局中视图的表达式。数据绑定库会自动生成绑定布局中视图与数据对象的所需类。库提供了导入、变量和包含等功能,您可以在布局中使用这些功能。
这些库功能与您现有的布局无缝共存。例如,可以在 UI 布局根元素的同级元素 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>
- 使用可观察数据对象
- 数据绑定库提供了类和方法来轻松观察数据的变化。您不必担心在底层数据源发生变化时刷新 UI。您可以使变量或其属性可观察。库允许您使对象、字段或集合可观察。
- 生成的绑定类
- 数据绑定库会生成绑定类,用于访问布局的变量和视图。本页面展示了如何使用和自定义生成的绑定类。
- 绑定适配器
- 对于每个布局表达式,都存在一个绑定适配器,它会执行框架所需的调用来设置相应的属性或侦听器。例如,绑定适配器可以负责调用
setText()
方法来设置文本属性,或者调用setOnClickListener()
方法来为点击事件添加侦听器。最常见的绑定适配器(例如本页示例中使用的android:text
属性的适配器)可在android.databinding.adapters
包中使用。有关常见绑定适配器的列表,请参阅 adapters。您也可以创建自定义适配器,如下面的示例所示
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 支持库包含 架构组件,您可以使用它来设计健壮、可测试且可维护的应用。您可以将架构组件与数据绑定库结合使用,进一步简化 UI 开发。
- 双向数据绑定
- 数据绑定库支持双向数据绑定。此类型绑定的表示法支持接收属性的数据更改,并同时监听对该属性的用户更新。
其他资源
要详细了解数据绑定,请参阅以下其他资源。
示例
Codelabs
博客文章
为您推荐
- 注意:当 JavaScript 关闭时,将显示链接文本。
- 绑定适配器 {:#binding-adapters}
- 布局和绑定表达式
- 生成的绑定类 {: #binding-classes}