Jetpack DataBinding使用--Jetpack系列

DataBinding是一种支持库,借助该库,可以使用声明性格式(而非程序化地)将布局中的界面组件绑定到应用中的数据源。布局通常是使用调用界面框架方法的代码在 Activity 中定义的。

1、引入支持
build.gradleandroid中添加如下代码,然后sync project

android {
        ...
        dataBinding {
            enabled = true
        }
 }

2、将现有xml布局转化为databinding布局 

首先需要配置以上开启databinding功能。然后在布局的中使用快捷键(我的是使用Alt+Enter),该快捷键在第6行之前的任意一处空白处才可调出,很重要!!!

 3、如我的"activity_databind.xml"布局转化成功之后的布局

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools">

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"

        android:layout_height="match_parent"
        tools:context=".MainActivity">

        <TextView
            android:id="@+id/text_onclick"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text='@{user.name+@string/mine + user.age}'
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

    </androidx.constraintlayout.widget.ConstraintLayout>
</layout>

4、定义一个UserBean数据源

public class UserBean {
    private String name;

    public UserBean(String name, String age) {
        this.name = name;
        this.age = age;
    }

    private String age;

    public String getName() {
        return name;
    }

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

    public String getAge() {
        return age;
    }

    public void setAge(String age) {
        this.age = age;
    }
}

5、activity_databind.xml布局中添加data数据绑定
 

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools">

    <data>
        <variable
            name="user"
            type="com.vick.componenttest.databinding.UserBean" />
    </data>

    <androidx.constraintlayout.widget.ConstraintLayout
        android:layout_width="match_parent"

        android:layout_height="match_parent"
        tools:context=".MainActivity">

        <TextView
            android:id="@+id/text_onclick"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text='@{user.name+@string/mine + user.age}'
            app:layout_constraintBottom_toBottomOf="parent"
            app:layout_constraintLeft_toLeftOf="parent"
            app:layout_constraintRight_toRightOf="parent"
            app:layout_constraintTop_toTopOf="parent" />

    </androidx.constraintlayout.widget.ConstraintLayout>
</layout>


然后布局会自动生成一个xml名称对应的类,如我的是ActivityDatabindBinding

6、DataBinding将视图与数据源绑定

public class DataBindActivity extends AppCompatActivity {
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //绑定视图
        ActivityDatabindBinding activityDatabindBinding=DataBindingUtil.setContentView(this, R.layout.activity_databind);
        UserBean userBean = new UserBean("我我我我","30");
        //后续可通过setUser对数据源做修改,视图将同步刷新
        activityDatabindBinding.setUser(userBean);
    }
}

以上即为DataBinding的一次简单示例,如有帮助,记得点赞~
 

猜你喜欢

转载自blog.csdn.net/qq_33539839/article/details/125502193