将 MVVM 演化为 MVVMM
众所周知,MVVM模式解决了Controller的臃肿并方便单元测试,为了方便后续代码维护,在上版本新功能开发中,项目开始使用MVVM模式进行开发。
但从上图可以看出,MVVM模式中,Controller即便清爽了,但无疑是将臃肿的代码移到了ViewModel中。
上述上个版本所开发的新功能为“爱疯抢”,从业务交互及界面状态展现来看,有多个界面存在相同的业务交互和元素展现,比如正在疯抢列表、疯抢商品详情、我关注的疯抢、我参与的疯抢等等,这些界面都存在抢拍、提醒、取消提醒、关注、取消关注、购买、支付已抢拍成功商品等业务交互,同时按钮展现(抢拍、提醒等状态切换)及时间展现(抢拍开始时间、抢拍中倒计时、下次抢拍时间)等展示逻辑也无差别。
因此,结合这些具体情形,我在模块类设计时,决定将这些公有的业务交互及界面展现状态转换逻辑抽离出来。依照MVVM设计模式,这些逻辑代码理应放到ViewModel中。
但从实际出发,如果将所有的逻辑的都放进ViewModel,将导致ViewModel变得十分臃肿,同时使得具体业务逻辑代码不够粒度化,这样无疑在代码上耦合严重、不利于代码扩展及重复利用。
举个例子,假如某些界面出现不同的展现方式及逻辑,但却具有相同的业务交互逻辑(抢拍、提醒、关注等),针对这种情况,就不能共用同一个ViewModel来满足了,这时不得不新写一个ViewModel来包含不同的展现逻辑和相同的业务交互逻辑,这无疑导致编写重复的业务交互代码,增加代码维护成本。
为了ViewModel最终不变得臃肿,同时利于代码扩展及重复利用,我想到将ViewModel的职责更进一步细化,ViewModel负责网络请求及界面展示逻辑,而将业务交互部分单独再抽出来,将其封装在独立的业务交互处理类Manager(或许这里取名Manager不恰当,暂且先这样)当中。
这样,不同展现逻辑但具有相同业务交互逻辑的界面即可使用不同的ViewModel而共用同一个Manager了,满足了一份业务交互逻辑代码可以多处使用、多处组装,在一定程度上不仅降低了开发工作量,同时增强了代码的可维护性。
我将这种演化后的模式称为MVVM+Manager模式,简称为MVVMM。Manager既然负责业务交互逻辑,这其中的业务就少不了和服务器交互、和本地数据交互等,因此,MVVMM模式的示意图可以定义为如下所示:
为了更具体说明MVVMM模式各个部分职责,我写了一个简明的逻辑描述Demo供参考。
对于复杂的功能模块,ViewModel仍然显得很臃肿的话,可继续将其职责再细化,例如将网络请求逻辑也从ViewModel中抽离出来单独成为一个处理类,类似猿题库中即使用单独的DataController类来负责网络数据请求,详情可以参考博文。
上述有不足或疑问之处请留言交流。
MVVMM Demo:http://download.csdn.net/detail/hbblzjy/9555333
参考文章:
ReactiveCocoa and MVVM, an Introduction
将 MVVM 演化为 MVVMM的更多相关文章
- 我理解的MVC
前言 前一阶段对MVC模式及其衍生模式做了一番比较深入的研究和实践,这篇文章也算是一个阶段性的回顾和总结. 经典MVC模式 经典MVC模式中,M是指业务模型,V是指用户界面,C则是控制器,使用MVC的 ...
- Web安全学习
项目地址(参考):https://websec.readthedocs.io/zh/latest/basic/history.html 本文只能充当目录简介,具体还要自己深入学习. 序章 Web技术演 ...
- [LeetCode] Interleaving String - 交织的字符串
题目如下:https://oj.leetcode.com/problems/interleaving-string/ Given s1, s2, s3, find whether s3 is form ...
- 安全协议系列(五)---- IKE 与 IPSec(上)
IKE/IPSec 属于网络层安全协议,保护 IP 及上层的协议安全.自上个世纪末面世以来,关于这两个协议的研究.应用,已经非常成熟.协议本身,也在不断地进化.仅以 IKE 为例,其对应的 RFC 编 ...
- webpack入门(一)——webpack 介绍
如今的网站正在演化为web应用程序: 1. 越来越多的使用JavaScript. 2. 现代浏览器提供更广泛的接口. 3. 整页刷新的情况越来越少,甚至更多代码在同一个页面.(SPA) 因此有很多代码 ...
- 【Networking】容器网络大观 && SDN 资料汇总
SDNLAB技术分享(十五):容器网络大观 SDNLAB君• 16-06-17 •2957 人围观 编者按:本文系SDNLAB技术分享系列,本次分享来自SDN撕X群(群主:大猫猫)群直播,我们希望 ...
- .net的五层架构
原文章地址是http://www.360doc.com/content/11/1210/21/19147_171335782.shtml 我们刚开始学习架构的时候,首先会想到分层的概念,分层架构比较经 ...
- Mac OS X 背后的故事
Mac OS X 背后的故事 作者: 王越 来源: <程序员> 发布时间: 2013-01-22 10:55 阅读: 25840 次 推荐: 49 原文链接 [收藏] ...
- H5版定点投篮游戏(1)--物理模型抽象
前言: 前几天目睹了大学同学开了个微店, 算是间接体验微信公众平台的使用. 觉得非常便捷和方便, 于是自己也想捣鼓一个. 公众号取名: "木目的H5游戏世界", 定位做成一个, 个 ...
随机推荐
- nginx平台初识(二) 浏览器 HTTP 协议缓存机制详解
1.缓存的分类 缓存分为服务端侧(server side,比如 Nginx.Apache)和客户端侧(client side,比如 web browser). 服务端缓存又分为 代理服务器缓存 和 反 ...
- Linux 高性能服务器编程——Linux服务器程序规范
问题聚焦: 除了网络通信外,服务器程序通常还必须考虑许多其他细节问题,这些细节问题涉及面逛且零碎,而且基本上是模板式的,所以称之为服务器程序规范. 工欲善其事,必先利其器,这篇主要来探 ...
- [Mysql]mysql windows下配置文件
环境是win7 mysql5.6版本 测试下配置文件是否可用(之前没用过windows下的msyql配置) 修改配置前查询下: mysql> show variables like '%max_ ...
- [error]error while loading shared libraries: libpcre.so.1 解决
nginx 安装好之后,启动的时候报错 [root@localhost nginx-1.6.2]# /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin ...
- 协议系列之IP协议
1.协议 协议(protocol)的定义:为计算机网络中进行数据交换而建立的规则.标准或约定的集合.两个终端相互通信时双方达成的一种约定,规定了一套通信规则,双方通信必须遵守这些规则.这些规则规定了分 ...
- Ant简介
Ant,apache开源项目,基于Java的构建工具,是一个小程序.它通过自动完成所有的编译代码,运行测试以及 打包重新部署等繁琐费力的任务来帮助软件团队开发大程序: Ant的目标是自动完成所有的构建 ...
- Nginx的负载均衡 - 最少连接 (least_conn)
Nginx版本:1.9.1 我的博客:http://blog.csdn.net/zhangskd 算法介绍 我们知道轮询算法是把请求平均的转发给各个后端,使它们的负载大致相同. 这有个前提,就是每个请 ...
- iOS中使用iCloud一些需要注意的地方(Xcode7.2)
大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 在自己的App中如何使用iCloud有很多文章可以查阅,这里把 ...
- Linux系统编程----僵尸进程
什么是僵尸进程? 僵尸进程, 指子进程退出后, 父进程还没有回收子进程的资源,这个子进程就处在于僵尸状态. 来看看如何产生? #include <stdio.h> #include < ...
- 【Unity Shaders】Transparency —— 透明的cutoff shader
本系列主要参考<Unity Shaders and Effects Cookbook>一书(感谢原书作者),同时会加上一点个人理解或拓展. 这里是本书所有的插图.这里是本书所需的代码和资源 ...