Android MVVM模式入门 - DataBinding的使用

简介: Android MVVM模式入门 - DataBinding的使用

 前言


2020.0405 更新- 本文只讲解DataBinding的使用,非架构MVVM

关于开发模式的文章,这应该算是第二篇,第一篇中讲解了Android MVP模式的使用:Android MVP模式 入门_黄林晴-androidmvp模式入门

mvp模式的优点就不说了,缺点其实在使用的过程中很显然,比如现在有个需求对数据库的学生表增删改查,那么view的接口,我们可能有如下定义

interface view{
    void get();
    void delete();
    void add();
    void update();
}

image.gif

我们在使用的View层继承下列接口即可,但如果有两个Activity,一个需要查询、一个需要修改、一个需要所有功能,那么这个时候如果我们继承这个view接口,肯定会出现View层含有没有使用的接口。当然我们可以将四个接口放在四个view层,但工作量和维护起来并不方便。

一、Android MVVM介绍

个人认为,MVVM的出现,并不是解决上述MVP的缺点,无论是MVP、MVC或是MVVM都有各自的缺点和优点,在开发中选择合适的开发模式,才能有助于开发工作。

   MVVM并不是分为了四层,而是将MVP中的P层变为了ViewModel层。还是以查询数据为例,如果我们要将查询出来的数据显示在控件上,我们要定义view层的如下方法

void setData(String data);

在Activity的接口回调中进行setText,但是如果显示的数据特别多,就要set多次,MVVM的最佳使用方式是MVP+DataBinding,MVVM可以实现数据直接和View层的控件绑定,和监听事件的绑定。接下来我们开始介绍MVVM的使用步骤。

二、DataBinding的使用步骤

2.1 引入Data Binding函数库

在build .gradle中使用如下设置支持dataBinding:

dataBinding{
    enabled = true
}

image.gif

2.2 新建一个User实体类

为了模拟数据我们新建一个User类如下

public class User {
    private String UserName;
    private String UserSex;
    public String getUserName() {
        return UserName;
    }
    public void setUserName(String userName) {
        UserName = userName;
    }
    public String getUserSex() {
        return UserSex;
    }
    public void setUserSex(String userSex) {
        UserSex = userSex;
    }
    public User(String userName, String userSex) {
        UserName = userName;
        UserSex = userSex;
    }
}

image.gif

2.3 编写xml布局,有两个textview一个显示UserName,另一个显示UserSex,在普通的xml布局中我们都是使用LinearLayout或者是其他的ViewGroup,但是在mvvm中我们使用的根布局是layout,xml布局代码如下所示:

 

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android">
    <data>
        <variable
            name="User"
            type="lonbon.com.mvvm.bean.User" />
    </data>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical">
        <TextView
            android:id="@+id/userName"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="@{User.userName}" />
        <TextView
            android:id="@+id/userSex"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="@{User.userSex}" />
    </LinearLayout>
</layout>

image.gif

布局中我们要注意的是这个data便签,其中type字段是数据绑定对应的实体类,name就是我们引用的一个属性标志,在这里写为User,如果要给textView赋值,我们直接通过@{User.属性},相当于把userSex属性变量赋值给id为userSex的TextView。

2.4 在Activity中引用

以为我们已经配置了databinding属性为true,所以会自动为我们生成Binding类,生成规则为布局名后面加Binding,比如我们这里的布局名称是activity_main,生成的Bingding类就是ActivityMainBinding,我们在Activity中通过下列代码使用:

ActivityMainBinding activityMainBinding = DataBindingUtil.setContentView(this, R.layout.activity_main);
User user = new User("黄林晴", "男");
activityMainBinding.setUser(user);

image.gif

我们通过DataBindingUtil获取databinding类直接与User数据绑定,运行程序,那么会直接将userName和userSex赋值到相应的值。

结果如图所示:

image.gif

如果我们是给ListView中的Item中的控件赋值,那么xml布局中的代码都是一致的,不同的是获取bingding类是使用

ListItemBinding bingding = ListItemBinding.inflate(layoutInflater,ViewGroup,false);

image.gif

 或者使用

ListItemBinding bingding = DataBindingUtil.inflate(layoutInflater,R.layout.activity_main,ViewGroup,false);

image.gif

三、DataBing使用之监听事件

DatabBing监听事件的使用其实个人感觉使用的效果并不好,因为现在差不多都是使用ButterKnife直接生成监听事件,不过还是要提一下,我们在之前的布局上加一个button,给button赋值监听事件,首先我们定义一个监听事件的类,我们可以在这个类中专门处理所有的监听事件,类似于js这也算一个好处吧。

3.1 定义一个Click类,声明一个test监听方法

代码如下所示:

public class Click {
    private String tag = "click";
    public void test(View v) {
        Log.d(tag, "点击事件触发了");
    }
}

image.gif

3.2 在xml中进行绑定

在data标签中再添加一个variable标签

<variable
    name="Click"
    type="lonbon.com.mvvm.click.Click"/>

image.gif

在button中为onclick属性设置

<Button
    android:text="text"
    android:onClick="@{Click.Text}"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" />

image.gif

最后记得在activity进行设置:

activityMainBinding.setClick(new Click());

image.gif

这里要注意的是并不是调用setClick方法,如果你新建的监听方法类是Text那么就要调用setText进行监听事件的绑定,我们来点击按钮,打印结果如下:

image.gif

DataBinding的使用主要就是这样了,还有一些功能需要深入研究,后续继续分享。

代码男人技术交流群



目录
相关文章
|
1月前
|
前端开发 JavaScript 测试技术
android做中大型项目完美的架构模式是什么?是MVVM吗?如果不是,是什么?
android做中大型项目完美的架构模式是什么?是MVVM吗?如果不是,是什么?
97 2
|
1月前
|
存储 前端开发 Java
Android MVVM架构模式下如何避免内存泄漏
Android采用MVVM架构开发项目,如何避免内存泄漏风险?怎样避免内存泄漏?
88 1
|
13天前
|
前端开发 JavaScript 测试技术
android做中大型项目完美的架构模式是什么?是MVVM吗?如果不是,是什么?
在 Android 开发中,选择合适的架构模式对于构建中大型项目至关重要。常见的架构模式有 MVVM、MVP、MVI、Clean Architecture 和 Flux/Redux。每种模式都有其优缺点和适用场景,例如 MVVM 适用于复杂 UI 状态和频繁更新,而 Clean Architecture 适合大型项目和多平台开发。选择合适的架构应考虑项目需求、团队熟悉度和可维护性。
40 6
|
23天前
|
存储 前端开发 测试技术
Android kotlin MVVM 架构简单示例入门
Android kotlin MVVM 架构简单示例入门
28 1
|
13天前
|
前端开发 Java 测试技术
android MVP契约类架构模式与MVVM架构模式,哪种架构模式更好?
android MVP契约类架构模式与MVVM架构模式,哪种架构模式更好?
22 0
|
1月前
|
前端开发 Java 测试技术
android MVP契约类架构模式与MVVM架构模式,哪种架构模式更好?
android MVP契约类架构模式与MVVM架构模式,哪种架构模式更好?
20 2
|
19天前
|
XML IDE Java
安卓应用开发入门:从零开始的旅程
【10月更文挑战第23天】本文将带领读者开启一段安卓应用开发的奇妙之旅。我们将从最基础的概念讲起,逐步深入到开发实践,最后通过一个简易的代码示例,展示如何将理论知识转化为实际的应用。无论你是编程新手,还是希望扩展技能的软件工程师,这篇文章都将为你提供有价值的指导和启发。
27 0
|
1月前
|
开发框架 移动开发 Android开发
安卓与iOS开发中的跨平台解决方案:Flutter入门
【9月更文挑战第30天】在移动应用开发的广阔舞台上,安卓和iOS两大操作系统各自占据半壁江山。开发者们常常面临着选择:是专注于单一平台深耕细作,还是寻找一种能够横跨两大系统的开发方案?Flutter,作为一种新兴的跨平台UI工具包,正以其现代、响应式的特点赢得开发者的青睐。本文将带你一探究竟,从Flutter的基础概念到实战应用,深入浅出地介绍这一技术的魅力所在。
76 7
|
2月前
|
Android开发 开发者
安卓开发中的自定义视图:从入门到精通
【9月更文挑战第19天】在安卓开发的广阔天地中,自定义视图是一块充满魔力的土地。它不仅仅是代码的堆砌,更是艺术与科技的完美结合。通过掌握自定义视图,开发者能够打破常规,创造出独一无二的用户界面。本文将带你走进自定义视图的世界,从基础概念到实战应用,一步步展示如何用代码绘出心中的蓝图。无论你是初学者还是有经验的开发者,这篇文章都将为你打开一扇通往创意和效率的大门。让我们一起探索自定义视图的秘密,将你的应用打造成一件艺术品吧!
60 10
|
1月前
|
Web App开发 编解码 视频直播
视频直播技术干货(十二):从入门到放弃,快速学习Android端直播技术
本文详细介绍了Android端直播技术的全貌,涵盖了从实时音视频采集、编码、传输到解码与播放的各个环节。文章还探讨了直播中音视频同步、编解码器选择、传输协议以及直播延迟优化等关键问题。希望本文能为你提供有关Andriod端直播技术的深入理解和实践指导。
44 0