Android DataBinding 与 MVVM

一、DataBinding 核心概念

定义 :DataBinding 是 Android Jetpack 的官方库,允许在布局文件中直接绑定 UI 组件到数据源,减少模板代码并实现自动更新。

核心优势

  1. 消除 findViewById() 调用

  2. 自动 UI 更新(数据变化 → UI 刷新)

  3. 支持双向绑定(UI 变化 → 数据更新)

  4. 布局表达式支持逻辑运算

  5. 与 MVVM 架构完美契合


二、配置与基础使用

1. 启用 DataBinding
Kotlin 复制代码
android {
    buildFeatures {
        dataBinding = true
    }
}
2. 基础布局绑定 (activity_main.xml)
XML 复制代码
<layout xmlns:android="http://schemas.android.com/apk/res/android">
    <data>
        <variable 
            name="user" 
            type="com.example.User" />
    </data>

    <LinearLayout>
        <TextView
            android:text="@{user.name}"  <!-- 单向绑定 -->
            android:visibility="@{user.isAdult ? View.VISIBLE : View.GONE}"/>
            
        <EditText
            android:text="@={user.email}" />  <!-- 双向绑定 -->
    </LinearLayout>
</layout>
3. 在 Activity/Fragment 中绑定
Kotlin 复制代码
class MainActivity : AppCompatActivity() {
    private lateinit var binding: ActivityMainBinding

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        
        // 数据绑定初始化
        binding = DataBindingUtil.setContentView(this, R.layout.activity_main)
        
        // 设置数据对象
        binding.user = User("John", "john@example.com", true)
        
        // 设置生命周期所有者(用于LiveData)
        binding.lifecycleOwner = this
    }
}

三、MVVM 模式集成 DataBinding

MVVM 架构图
bash 复制代码
[View] ---(观察)---> [ViewModel] <---(管理)---> [Model]
   ↑                      |
   └──(DataBinding绑定)──┘
1. 创建 ViewModel
Kotlin 复制代码
class UserViewModel : ViewModel() {
    // 使用 LiveData 实现数据观察
    private val _user = MutableLiveData<User>()
    val user: LiveData<User> = _user

    // 双向绑定的可观察字段
    val inputText = ObservableField<String>("")

    init {
        _user.value = User("Alice", "alice@domain.com", true)
    }

    // 处理 UI 事件
    fun updateUser() {
        _user.value = User(inputText.get() ?: "", "", true)
    }
}
2. 更新布局绑定
Kotlin 复制代码
<data>
    <variable 
        name="viewModel" 
        type="com.example.UserViewModel" />
</data>

<TextView
    android:text="@{viewModel.user.name}" />
    
<EditText
    android:text="@={viewModel.inputText}" />  <!-- 双向绑定到ViewModel -->

<Button
    android:onClick="@{() -> viewModel.updateUser()}" />  <!-- 绑定点击事件 -->
3. Activity/Fragment 集成
Kotlin 复制代码
class MainActivity : AppCompatActivity() {
    private val viewModel: UserViewModel by viewModels()

    override fun onCreate(savedInstanceState: Bundle?) {
        val binding: ActivityMainBinding = DataBindingUtil.setContentView(this, R.layout.activity_main)
        
        // 绑定 ViewModel
        binding.viewModel = viewModel
        
        // 设置生命周期所有者
        binding.lifecycleOwner = this
    }
}
相关推荐
野生的码农7 小时前
放过自己,降低预期,及时行乐
android·ai编程
huwuhang7 小时前
索尼PS3游戏合集【中文游戏】8.12T 1430个游戏+PS3模拟器
android·游戏·智能手机·游戏机·电视
Grackers9 小时前
Android Perfetto 系列 5:Android App 基于 Choreographer 的渲染流程
android
踩着两条虫9 小时前
AI驱动的Vue3应用开发平台深入探究(十):物料系统之内置组件库
android·前端·vue.js·人工智能·低代码·系统架构·rxjava
sam.li10 小时前
JADX MCP 原理与使用部署
android·逆向·jadx
冬奇Lab10 小时前
Android 15音频子系统(五):AudioPolicyService策略管理深度解析
android·音视频开发·源码阅读
亚历克斯神10 小时前
Flutter for OpenHarmony: Flutter 三方库 mutex 为鸿蒙异步任务提供可靠的临界资源互斥锁(并发安全基石)
android·数据库·安全·flutter·华为·harmonyos
dalancon12 小时前
SurfaceControl 的事务提交给 SurfaceFlinger,以及 SurfaceFlinger 如何将这些数据设置到对应 Layer 的完整流程
android
dalancon12 小时前
SurfaceFlinger Layer 到 HWC 通信流程详解
android
cccccc语言我来了12 小时前
Linux(9)操作系统
android·java·linux