阿里P7移动互联网架构师进阶视频(每日更新中)免费学习请点击:https://space.bilibili.com/474380680
前言:
2015年谷歌I/O大会上介绍了一个数据绑定框架DataBinding。2016年,2017年毫无意外成了项目实战中主流框架。使用它我们可以轻松实现MVVM(模型-视图-视图模型)模式,来实现应用之间数据与视图的分离、视图与业务逻辑的分离、数据与业务逻辑的分离,从而达到低耦合、可重用性、易测试性等好处。而使用DataBinding不仅减少了findViewById的出现频率,而且还大大提高解析XML的速度。
1 . 基本使用
新建一个项目,在app的build文件加上:
构建环境特别简单,接下来直接开始使用数据绑定
首先,新建一个User.java实体类:
之后看下布局(activity_basic.xml),跟传统的布局不一样,这里需要使用<layout></layout>作为根节点,在<layout>节点中我们可以通过<data>节点来引入我们要使用的数据源
注意 :
※ 切记,在<layout>节点下是没有“layout_width”和“layout_height”的
※ type中声明的就是我们的用户实体类User,连同包名一定要写全!!!我们给其命名(name)为“user”,然后在TextView中的@{user.name}就是把这个user中的名字展示出来,之后的“age””myBlog”同理
※ age年龄在实体类User中我们定义的是整数类型,所以在布局中需要使用String.valueOf(user.age)转换为字符串
一个Binding类会基于layout文件的名称而产生,并且添加“Binding”后缀。上述的layout文件是main_basic.xml,因此生成的类名是ActivityBasicBinding。通过DataBindingUtil.setContentView获取bing实例,进行数据绑定
运行之后看下效果图
2 . 显示照片
看完图之后,我们看下如何实现。
我们选择用glide加载一张网络图片。glide怎么在studio中使用,这里就不再讨论。如何显示一张网络图片,需要使用到DataBinding自定义属性@BindingAdapter。在布局文件中使用这个自定义属性,显示出我们要展示的布局。
还是那个实体类User,添加自定义属性@BindingAdapter({"imageUrl"})
※ 这里要主要的是,imageLoader方法必须声明是static,否则会报错。
新建activity_image.xml,因为使用了自定义属性,所以在layout节点下要添加xmlns:app="http://schemas.android.com/apk/res-auto"。在ImageView中使用app:imageUrl="@{user.imageUrl}"。完整代码如下:
最后运行之后,结果如上图。我就不再发一遍了,有兴趣的朋友再拖回去看一遍,反正下面还有~~
3 . 更多用法
简单的字符拼接
简单的三目运算
判断名字是否为空,不为空只显示user.name,否则显示donkor11:
相当于
这里需要注意的是当{}中使用了双引号“”,最外层要改成单引号”
根据数据判断,显示数据
判断是否为学生,是则显示11,反则,显示00
**修改样式 **
判断是否为学生,是则修改背景颜色0xFF0000FF,反则,显示0xFFFF0000
写在之后的话,这里我们需要知道Databinding支持与不支持的表达式,语法。如下
支持的表达式:
1.Mathematical + - / * %
2.String concatenation +
3.Logical && ||
4.Binary & | ^
5.Unary + - ! ~
6.Shift >> >>> <<
7.Comparison == > < >= <=
8.instanceof
9.Grouping ()
10.Literals - character, String, numeric, null
11.Cast
12.Method calls
13.Field access
14.Array access []
15.Ternary operator ?:
不支持的表达式:
1.this
2.super
3.new
4.Explicit generic invocation
最后运行之后,看下效果图。
4 . 点击事件
单击事件
单击事件在实际开发中,使用频率有多高这里就不解释了。下面我们直接看怎么用
在data节点下的variable下type引用android.view.View.OnClickListener。
Button按钮直接引用”myClick”
长按事件
长按事件的button,首先需要分配一个id给Button
在Activity中,使用数据绑定,直接引用按钮id。完整代码如下
最后运行之后,看下效果图。
▲5 . 绑定ListView
Listview在实际开发中使用频率同样很高,看了上面那么多例子。就知道Databinding绑定ListView一样简单。接下来看一组美图。
看完之后,能看出布局其实就是一张ImageView,底下加一个TextView。例子很简单 ,然后看下如何实现。首先需要新建一个美女的实体类,我们先定义Beauty,beautyNum就是美女底下的TextView文本。
然后看下主布局activity_listview.xml,在data节点下的variable下type引用android.widget.BaseAdapter。
然后ListView的item布局item_listview.xml,同样比较简单,在这不做解释。
有ListView的地方,十有八九就有适配器。这里介绍一个终极适配器的写法MyBaseAdapter。尽管这里仅仅是给美女使用的适配器,但是已经说明了是终极写法。我们就不叫它美女适配器了。
然后解释下其中几个变量
Context context:上下文,不比多说
List list:传进来的数据集合,不解释
int layoutId: item布局的资源id
int variableId:系统自动生成的
※ 注意布局加载方式为DataBindingUtil类中的inflate方法
最后看下ListViewActivity完整代码
最后运行之后,结果如上图。有兴趣的朋友再拖回去看一遍,反正下面没有美女了~~
6 . 数据更新
Databinding的数据更新同样惹人喜欢。最主要的是代码简洁明了,UI还同步更新。
首先看下效果图
数据更新可以使用如下两种方式,分别对学生文本和老师文本进行修改
让实体类(Student)继承自BaseObservable
给需要改变的字段的get方法添加上@Bindable注解,然后给需要改变的字段(例如name)的set方法加上notifyPropertyChanged(BR.name);字段number同理,在set方法内加上notifyPropertyChanged(BR.number);
** 使用DataBinding提供的ObservableFields来创建实体类**
Teacher实体类,这个更加简单,几行代码搞定
然后看下布局文件activity_data_notify代码,跟上文描述的基本类似,这里不再过多赘述。
最后看下DataNotifyActivity完整代码
7 . 数据集合
DataBinding中给我们提供了一些现成的集合ObservableArrayList,ObservableArrayMap。这里不做介绍。
Demo_CSDN 下载地址 : http://download.csdn.net/detail/donkor_/9740166
原文链接:https://blog.csdn.net/donkor_/article/details/54598215
阿里P7移动互联网架构师进阶视频(每日更新中)免费学习请点击:https://space.bilibili.com/474380680