Android官方DataBinding简例(一)

本文介绍如何使用Android官方DataBinding简化UI与数据交互。通过启用DataBinding并创建User JavaBean,将数据直接绑定到XML布局文件中,实现动态更新UI。示例展示了从启用DataBinding到绑定数据的完整流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android官方DataBinding简例(一)

(1)使用谷歌Android官方DataBinding,需要首先在module的gradle里面启用:
android {
   
	...


    dataBinding {
        enabled = true
    }


	...

}

配置完成后记得update gradle,刷新工程。


(2)接下来要建立一个Java bean数据对象结构,假设建立一个简单User的数据容器,里面有变量id,name,blog基础类型:
package zhangphil.test;

/**
 * Created by Phil on 2017/8/17.
 */

public class User {
    private String id;
    private String name;
    private String blog;

    public User(String id, String name, String blog) {
        this.id = id;
        this.name = name;
        this.blog = blog;
    }

    public void setId(String id) {
        this.id = id;
    }

    public String getId() {
        return this.id;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getName() {
        return this.name;
    }

    public void setBlog(String blog) {
        this.blog = blog;
    }

    public String getBlog() {
        return this.blog;
    }
}


(3)Android DataBinding和以往编程模型不同的是,需要在Android 布局里面直接给定。在过去,假如我需要在一个垂直线性布局使用三个TextView显示id,name,blog,那么现在新的做法是引入一个layout,在这个根layout里面,把数据容器bean(本例是User)和TextView直接绑定:
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">
    <data>
        <variable
            name="user"
            type="zhangphil.test.User" />
    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{user.id}"
            android:textColor="@android:color/holo_red_light" />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{user.name}"
            android:textColor="@android:color/holo_red_light" />

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{user.blog}"
            android:textColor="@android:color/holo_red_light" />
    </LinearLayout>
</layout>
可以看出和过去的布局写法没有太大不同,只是用了一个layout包括一层,引入一个data元素结点,variable“注入”我们要和当前View绑定的数据模型(model)。注意看到在TextView定义android:text属性文本值时候,使用的特别注解符号和形式。


(4)以上完成后,就可以直接在上层Java代码直接用ActivityMainBinding像胶水一样把User bean模型和View绑定在一起:
package zhangphil.test;

import android.databinding.DataBindingUtil;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import zhangphil.test.databinding.ActivityMainBinding;

public class MainActivity extends AppCompatActivity {
    private String name = "zhangphil";
    private int id = 1;
    private String blog = "http://blog.csdn.net/zhangphil";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //setContentView(R.layout.activity_main);

        ActivityMainBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
        User user = new User(String.valueOf(id), name, blog);
        binding.setUser(user);
    }
}

注意:ActivityMainBinding由Android studio自动生成,简单起见,本例不需由开发者维护。


代码运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhangphil

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值