为什么还要在Activity中写业务代码?

经过一年的努力推动,公司研发部门同事终于走上了规范之路。对于旧项目的代码维护真是苦不堪言,一个OTA升级项目的实现,仅用了三个类实现所有的功能,修个小bug,用了两天在看整个项目代码怎么实现的...动一下就崩一下那种。

所以,能告诉我,为什么还要在Activity中写业务代码么?

MVVM模式浅谈

关于Android的MVVM开发框架,可能是老生常谈。与如停留在概念上讲解,不如与实战开发一起来说说。与MVC、MVP等模式的设计理念是一致的,就是为了解耦,方便后期维护和功能迭代。

image

MVVM模式在Android可以解读以下三个对象:

View: 这样指的应该是Activity、Fragment等UI控制器以及相关具体的View,当然也包括xml布局文件。主要负责界面的实现和与用户的交互。

Model: 数据模型,可以说,是应用对外数据交互的接口。在Model层关心的应该是数据。例如根据应用的不同环境或逻辑,从网络或者本地获取数据,为ViewModel提供数据。

ViewModel:View与Model交互的桥梁,也是应用逻辑实现的地方。将曾经大量在View层实现的逻辑代码转移到自身,从而减少UI控制器代码的臃肿。

采用MVVM模式在实际开发带来的好处是什么?

  • 解耦 三个层各司其职,专心负责自己的工作,例如Model层只负责数据的获取,为内部提供数据资源。不用处理ViewModel层的业务逻辑。
  • 整洁,清晰 解耦之后,应用功能的实现非常整洁,思路也非常清晰,在哪个类该实现View,哪里类应该实现数据请求一目了然,不存在代码和逻辑相互嵌套等导致后期项目难以维护的问题。
  • 协作 在人力充足情况,可以多人负责一个层或者一人负责一个层,然后为另外一个层提供接口。

不可避免的是,无论是MVC、MVP还是我们所说的MVVM模式,都会导致类和代码的增加,但请相信,这值得去做。

实战中整体框架思路

View层

View层只关心和UI相关的工作,我们只在Activity、Fragment和xml布局写和UI相关代码,以及和用户的交互,例如监听用户的点击View之后,应该通知ViewModel去处理相关业务逻辑,而不是在Activity中处理。

更希望的时候,通过数据驱动来改变View,而不是View通知ViewModel有相关交互。例如,通过Jetpack中DataBinding来实现双向绑定。View的点击事件直接传递到ViewModel层,ViewModel层处理相关逻辑。或者View层监听ViewModel的LiveData变量,在数据发生变更时更改View。而不是View层为ViewModel层提供View改变的接口。

下面是View层一些推荐文章:

ConstraintLayout

DataBinding

LiveData

ViewModel层

ViewModel担任着View与Model交互的桥梁和业务逻辑的处理,具有举足轻重的地位。这里我们推荐使用Jetpack的ViewModel,至于能带来什么好处,可以看下文的链接。一定要记住,不要在ViewModel层去更新UI或者获取数据,它只负责UI和数据逻辑的交互,但不负责View层 和Model层的工作。一般View层都会持有一个ViewModel实例,通过实例来操作数据,而操作结果通过改变LiveData的值,来做相关UI改变,例如更新数据展示。

Jetpack的ViewModel

Model层

Model层负责数据的获取,转为实体对象,映射到ViewModel层。ViewModel层一般持有Model实例,操作Model提供的接口。对于网络请求,一般推荐使用Retrofit,数据库推荐Room。在Model实现的操作一般都是耗时的,Java开发配合RxJava,Kotlin开发使用协程,效果最佳。对实体对象的返回,常有回调函数和EventBus来处理。

下图是以MVVM模式开发的用户登录:


image

终生愿望:希望各位研发同志早日用上开发框架MVVM也好,MVP也罢。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容