Android Data Binding初次使用

来源:互联网 发布:2016年8月淘宝活动 编辑:程序博客网 时间:2024/05/29 17:32

Data Binding
Data Binding即数据绑定,Data Binding 库实现在布局文件中实现数据绑定申明,使数据的变化引起视图的自动更新,减少了逻辑代码,在Android中可以很方便的实现MVVM的开发模式
最近看到网上和群里各种MVVM,带着兴趣简单的了解了下,初次使用,各种问题,在这里总结下。

1、构建环境

要开始使用Data Binding,首先需要在Android SDK Manager的支持库里下载该库
请确保您使用的是 Android Studio 的兼容版本。Android Studio的Data Binding 插件需要 Android Studio 1.3.0-beta1 或更高版本,我用的是1.3.2。

2、工作环境

你的app要使用Data Binding,需要添加Data Binding到gradle构建文件里,如下:
很多人介绍的是

 dependencies {       classpath "com.android.tools.build:gradle:1.2.3"       classpath "com.android.databinding:dataBinder:1.0-rc0"   }

然后确保jcenter在repositories列表里,如下:

allprojects {   repositories {       jcenter()   }}

在每一个你想要使用Data Binding的module,添加如下的插件:

apply plugin: ‘com.android.application'apply plugin: 'com.android.databinding'

但是我项目里就各种报错,就是gradle选的更高版本1.3也还是报错,然后找了找可以用dataBinder:1.0-rc1,然后我就改成了如下这样,并且成功了

classpath 'com.android.tools.build:gradle:1.3.0'classpath "com.android.databinding:dataBinder:1.0-rc1"

3.Data Binding Layout 文件

穿件文件这里再次遇到了问题,我是new–>Layout Resource File然后在Root element里面选择的layout,这样创建的文件是这样的格式

<?xml version="1.0" encoding="utf-8"?><layout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="match_parent" android:layout_height="match_parent"></layout>

系统默认创建的带android:layout_width和android:layout_height两个属性,事实证明如果layout有这两个属性是编译不通过的,得删掉。
Data Binding layout文件有点不同的是:起始根标签是 layout,接下来一个 data 元素以及一个 view 的根元素。这个 view 元素就是你没有使用Data Binding的layout文件的根元素,举例说明:

<?xml version="1.0" encoding="utf-8"?><layout xmlns:android="http://schemas.android.com/apk/res/android">    <data>        <variable            name="user"            type="com.leju.myapplication.UserBean" />    </data>    <LinearLayout        android:layout_width="match_parent"        android:layout_height="match_parent"        android:background="#fff"        android:orientation="vertical">        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="@{user.name}" />        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="@{user.num}"/>        <TextView            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:text="@{@string/hello_world + String.valueOf(user.age) }"/>        <ImageView            android:id="@+id/imageview"            android:layout_width="wrap_content"            android:layout_height="wrap_content" />    </LinearLayout></layout>

在layout的属性表达式写作@{},下面是一个TextView的text设置为user的firstName属性
在 data 内描述了一个名为user的变量属性,使其可以在这个layout中使用,UserBean对象如下:

public class UserBean {    public final String name;    private String num;    private int age;    public UserBean(String name) {        this.name = name;    }    public String getNum() {        return num;    }    public void setNum(String num) {        this.num = num;    }    public int getAge() {        return age;    }    public void setAge(int age) {        this.age = age;    }}

在layout中我们通过@{user.name}调用name知道给textview设置值,通过@{user.num}来调用num字段赋值,这里的UserBean的name和num虽然创建方式不一样,但是调用方式都是相同的,这两种方式是等价的。
通过@{@string/hello_world + String.valueOf(user.age) }这句我们可以发现,可以调用我们创建的color string等资源文件,还有就是因为age字段是整形,所以直接赋值的话肯定会报错,我们这里可以用String.value给转下型。

4、绑定数据

layout和bean对象都创建成功之后我们将要在activity中显示了,代码如下:

    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        ActivityTestBinding binding = DataBindingUtil.setContentView(this,R.layout.activity_test);        UserBean userBean = new UserBean("hello");        userBean.setNum("123");        userBean.setAge(12345);        binding.setUser(userBean);        //在layout中对控件设置id,可以根据id名直接获取控件        binding.imageview.setImageResource(R.mipmap.ic_launcher);    }

这样就可以达到效果了,你要对界面显示进行操作。只需要针对这个实例进行操作就OK了,感觉确实很方便,但是这里说一句,data binding没有代码自动补全,这点太恶心了。

0 0