MVC、MVP又到MVVM,随着技术的进步,开发设计模式也在演进,Google在2015 IO 大会上带来的 Data Binding 库使得 Android 开发者可以方便的实现 MVVM 架构模式。使用DataBinding可以改善应用程序的开发,使代码更加干净优雅。本文将简单介绍DataBinding框架,通过实例展示其用法,算是当一个官网的翻译搬运工吧。
一. DataBinding简介
DataBinding是一种新的Android布局书写方式,一个布局XML可以和一个数据Model绑定在一起。Model发生变化,View也会相应发生变化。
二. 演示DataBinding的简单用法
1.在Grandle文件里配置使用DataBinding,注意Grandle工具必须在1.5.0版本以上。
android {
....
dataBinding {
enabled = true
}
}
2. 建立一个数据Model,表示一个人,属性就一个名字
public class UserInfo {
public String name;
public UserInfo(String name) {
this.name = name;
}
}
3. 在布局文件里绑定数据Model。
注意新的布局文件的写法,layout作为了根元素,用data标签引入将要使用的数据Model。
<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">
<data>
<variable
name="user"
type="com.example.administrator.myapplication.UserInfo"
/>
</data>
<LinearLayout
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical"
tools:context="com.example.administrator.myapplication.MainActivity"
>
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginBottom="50dp"
android:gravity="center"
android:text="@{user.name}" //绑定数据Model的响应属性
android:textSize="15sp"
/>
<Button
android:id="@+id/button"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="动态改变Model的值"
/>
</LinearLayout>
</layout>
4. 在Activity建立两者的绑定关系。
-
注意ActivityMainBinding的写法,根据官网的说法,Binding对象和布局文件是一一对应的,生成的Binding对象的名字规则是在布局文件的“大驼峰名字法+Binding(后缀)”。
-
比如下面代码中的布局文件是activity_main,按照上述规则,其对应的Binding对象的名字就是ActivityMainBinding。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
final ActivityMainBinding binding = DataBindingUtil.setContentView(this, R.layout.activity_main);
//新建一个人物数据Model,取名王二狗
final UserInfo user = new UserInfo("王二狗");
binding.setUser(user);
Button btn = (Button) findViewById(R.id.button);
btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) { //点击按钮,改变数据Model的名字,重新绑定数据
user.name = "李三蛋";
binding.setUser(user);
}
});
}
}
-
binding.setUser(user);绑定完成后可以看到界面上的TextView显示出了Model的name属性的值。
image -
上面代码中使用了一个按钮,点击动态改变Model的名字属性,从下面的Gif图中可以看到,Model的值被改变后,TextView显示的名字也改变了。
image
总结
DataBinding 帮助开发者完成了把Model的值赋值给响应控件的工作,是对MVVM设计模式的一种体现。
网友评论