还记得在博客《高逼格UI-ASD(Android Support Design)》的开始曾经说过,Android最新推出了一个官方的数据绑定框架-Data Binding Library。现在github上也有很多三方的数据绑定框架,但是我们为什么要选择官方的呢?恩,答对了。就是因为是官方的,三方的东西说不定什么时候作者一步高兴就停止更新了,官方的就不一样了,我们可以看到它渐渐的稳定起来。好了废话不多说,从这篇博客开始,我们就来了解一下android最新给我们带来的数据绑定框架——Data Binding Library。数据绑定框架给我们带来了更大的方便性,以前我们可能需要在Activity
里写很多的findViewById
,烦人的代码也增加了我们代码的耦合性,现在我们马上就可以抛弃那么多的findViewById
。说到这里,有人可能会有个疑问:我使用一些注解框架也可以不用findViewById
啊,是的,但是注解注定要拖慢我们代码的速度,Data Binding则不会,官网文档说还会提高解析XML的速度,最主要的Data Binding并不是单单减少了我们的findViewById
,更多好处请往下看文章。
一、环境
在开始使用新东西之前,我们需要稍微的配置一下环境,这里要求你的Android Studio版本是1.3+,使用eclipse的同学暂时还没有办法使用该框架,请换用Android Studio。还有,在开始之前,请更新你的Support repository
到最新的版本。
万事俱备,那我们就开始搭配环境!
新建一个project
,在dependencies
中添加以下依赖
classpath "com.android.databinding:dataBinder:1.0-rc1"
新建module
,并且在module
的build.gradle文件中添加
apply plugin: 'com.android.application'
apply plugin: 'com.android.databinding'
ok,到现在为止,我们的环境就准备完毕了,下面我们就开始Data Binding的学习啦。
二、Data Binding尝试
在代码开始,我们并不直接进入新东西的讲解,而且以一段代码展现Data Binding的魅力。
首先我们需要一个java bean
,很简单,一个学生类。
public class Student {
private String name;
private String addr;
public Student() {
}
public Student(String name, String addr) {
this.name = name;
this.addr = addr;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAddr() {
return this.addr;
}
public void setAddr(String addr) {
this.addr = addr;
}
}
再来看看我们布局文件怎么写:
<layout xmlns:android="http://schemas.android.com/apk/res/android">
<data>
<variable
name="stu"
type="org.loader.androiddatabinding.Student" />
</data>
<LinearLayout
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@{stu.name}"/>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@{stu.addr}"/>
</LinearLayout>
</layout>
可以看到我们的xml布局和以前还有有一定的差别的,但是差别也不是很大。
最后来看看Activity
怎么写。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ActivityMainBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
binding.setStu(new Student("loader", "山东莱芜"));
}
}
Activity
的代码非常简单,就添加了两行代码,而且,值得注意的是:我们并没有findViewById
然后再去setText
。
这段小代码运行的结果大家可能已经猜到了,就是在界面上显示loader
和山东莱芜
两句话。
)
在看完小实例后,大家是不是感觉棒棒哒? 没有了之前的find控件,没有了setText,Activity
代码更加简洁明了!
下面开始,我们进入Data Binding的学习!
三、 初始Data Binding
上面的代码算是带领我们进入了Data Binding的世界,那我们先从布局文件开始入手Data Binding吧。再来看看上面的布局文件。
<layout xmlns:android="http://schemas.android.com/apk/res/android">
<data>
<variable
name="stu"
type="org.loader.androiddatabinding.Student" />
</data>
...
</layout>
我们的根节点变成了layout
,在layout
的子节点中分成两部分,第一部分是data
节点,第二部分才是我们之前的根节点,在data
节点下我们又定义了一个variable
,
从名称上看,这应该是一个变量,变量的名称是stu
,类型是org.loader.androiddatabinding.Student
,这类似我们在java文件中这么定义:
org.loader.androiddatabinding.Student stu;
ok,这样很好理解了吧,不过这里要写Student
完整的包名,一个还好,如果这里我们需要多个Student
呢?要累死? NO,NO,NO,我们还可以向写java文件那样导入包。
<layout xmlns:android="http://schemas.android.com/apk/res/android">
<data>
<import type="org.loader.app2.Student" />
<variable
name="stu"
type="Student" />