您的位置:首页 > 运维架构 > 网站架构

Android MVVM架构设计模式,从DataBinding开始

2018-03-20 11:38 555 查看
    MVVM在android端已经出了很久了,但是还是比较少使用到,现在写Android架构设计的时候比较多使用的是MVP,以前在用Angularjs和Vue接触过双向数据绑定的使用和思想,所以看到MVVM一种熟悉的感觉,现在来说说个人的基于MVP进行分析MVVM的DataBinding。
   先说MVP是怎么过渡到MVVM的。
 分析:MVP是对三层结构的解耦,而MVVM是把MVP中的P层换成了ViewModel层,而通过双向数据绑定来获取用户输入的数据来通知model层去访问网络,所以现有开发框架只要把P层进行替换,然后加入DataBinding就变成了MVVM,加快了加载布局的速度,耦合性没有很大的改变,还是保留了MVP的特性,现在来看怎么使用。
    1、在app下的builde.gradle添加如下,开始支持双向数据绑定。
dataBinding {
enabled = true
}
    2、构造model类。package com.xwsd.android.myframework.model.bean;
public class User {

private String name;
private String age;

public User(String name, String age) {
this.name = name;
this.age = age;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public String getAge() {
return age;
}

public void setAge(String age) {
this.age = age;
}
}
   3、在布局中使用,以layout为外层布局,而不是我们指定的基本布局,引入data对象,让对象能够在文本中使用。<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">

<data>

<variable
name="user"
type="com.xwsd.android.myframework.model.bean.User"/>
</data>

<LinearLayout
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
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="@{String.valueOf(user.age)}"/>
</LinearLayout>

</layout>   4、在activity或者fragment中进行使用,代码写了注释,通过以下方法就可以进行MVVM操作了。
import android.databinding.DataBindingUtil;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;

import com.xwsd.android.myframework.R;
import com.xwsd.android.myframework.databinding.ActivityHomeBinding;
import com.xwsd.android.myframework.model.bean.User;

public class HomeActivity extends AppCompatActivity {
private ActivityHomeBinding activityHomeBinding;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
activityHomeBinding= DataBindingUtil.setContentView(this,R.layout.activity_home);
//        model层访问网络后进行数据更新操作
activityHomeBinding.setUser(new User("张三",20));
//        用户输入后获取用户输入,然后把数据给model进行网络请求。
User user=activityHomeBinding.getUser();

}
}
     总结:MVVM中的数据绑定还是比较简单的,这个只是一个小的应用,如果项目中需要用到双向数据绑定可以以此类推使用,掌握了设计的思想,使用起来就会简单的多,上手直接使用,重要的是有这样的思想。
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: