接下来两种方法都可以实现我们的需求 为了方便我们测试,我先在页面里增加一个按钮,增加了点击事件,每次点击我就把数字加1,我们在为做任何处理之前,怎么点,页面数据也不会发生变化。
image.png来到我们的数据类这里 ,将我们的数据类继承BaseObservable,注意这个类是android.databinding.BaseObservable;
在我们的get上面加上@Bindable,在set后面加上notifyChange();
image.png
点击运行下程序,我们会发现随着我们的点击,textview里面显示的数据会不断的变化
当然我们也可以在set里面将notifyChange()改为 notifyPropertyChanged(BR.XXX)
image.png image.png
有的朋友好奇怎么就notifyPropertyChanged(BR.name)了呢?
来往布局文件看,其实每次我们布局文件写完,BR里面就会自动生成一个id一一对应。
notifyChange()和 notifyPropertyChanged(BR.name)的区别就在于前者是把所有涉及这个数据类的都刷新,后者是只刷新数据类对应参数比如我们的只刷新我们的name值,有点类属于我们锁机制里面的 notify和 notifyAll
我们测试下,新增个参数 name2,name2上不写@Bindable和notifyChange();
布局文件里增加一个textview,引用name2,我们每次刷新也刷新name2,如图
image.png
点击测试,嚯,name2的值也跟着变化了,点击了5下,变成了20,从15变成了20
image.png看来我们说的刷新整个数据类是对的,然后我们将notifyChange()改为 notifyPropertyChanged(BR.name)
运行,点击5下,试试,嚯,居然见数据name变化,name2不会刷新,所以我们的猜想是正确的
第二种方式,引用ObservableFields,不过需要包装一下
注意箭头哦 这里有一波福利就是不用写get和set了,在使用的时候会出现set()
image.png
name 和age出来了,我们按照我们的套路试试,修改代码,点击试试
报了个错
image.png
是因为我们布局文件里写个了name2,但是实际我们已经没有了,当然布局文件也不会爆红,这个也算是一点不好点地方吧,删掉name2我们继续运行
image.png
怎么崩溃了,运行提示我们输入的字符串有错,好像看起来没啥错,我们发现bean类那里将继承删除掉,运行下
image.png image.png
怎么还是崩溃呢?
image.png
想到null指针,既然有set方法,那么这个空指针指的是我们name么?初始化以下,继续运行
image.png
终于能运行了,我们点击几下
image.png
终于可以运行了,所以学习新知识,是个摸索的过程
其实我们还可以使用提供好的基本类型,但是习惯使用String的我,觉得还是Filed好用
image.png