iOS应用架构之Model的思考

前言

作为一个并不是很有经验的开发者而言, 不敢妄论架构二字, 只是对目前市面上一些常见的架构中的一小部分--Model部分--有一些思考. 这些思考也是基于我在实际编写代码中所遇到的问题所引发的. 因此我想抛出这个问题, 希望大家一起来探讨.

问题

市面上比较流行的两大应用开发架构是MVC和MVVM, 让我很奇怪的是, 无论是MVC还是MVVM, 都对Model有无以伦比的"洁癖", 也就是说在model里面只描述业务对象, 坚决不加入任何其它代码. 为什么呢? 我思考了很久, 没有找到能让我认同的观点, 因此我在下面的篇幅中会阐述我对iOS应用架构中Model定位的理解.

想法

在继续讨论这个问题之前, 我先说说个人对什么是好的架构或者好的代码的一点点思考, 仅仅是个人的思考, 不代表说一定正确.
每次我们谈到好的架构或者代码的时候都会说: 通俗易懂, 有拓展性, 易修改, 足够健壮等等等等. 但是在我看来都是表现, 我认为好的代码归根结底就一点--高复用性. 如果代码写的很晦涩不好修改, 那么就无所谓复用了, 如果有足够的人力物力迟早会被人重构掉;
如果代码拓展性不好, 不能适用新的业务场景, 那么就需要重新造一个新的类出来实现, 自然也没有复用度可言;

(当然, 并不是说好的代码或者架构就一定是复用度极高的, 这中间有一定的平衡, 一味追求高复用度最后造成的结果就是接口很难用, 这个问题不在本题讨论范围内)

作为业务描述的Model, 复用度会高吗? 从我的经验来讲, 基本不会有复用的, 除非一种情况就是外面是summary里面是detail的情况, 这种情况一般会detailModel继承summaryModel来复用一部分代码. 但是这种情况不影响继续讨论这个问题, 因为本质上是属于同一个业务, 我所要表达的是, 既然绝大多数的情况下, 我们不可能把一个业务的Model复用到另外一个业务上, 那么为什么不把一些额外逻辑写在Model上面呢?

这个想法起源于MVVM这个架构, 为了解放Controller, MVVM中引入了ViewModel这么个概念, 但我个人认为, 只要把一部分逻辑写到Model中是可以减轻一部分Controller的负担的并且不用担心会有其它副作用, 例如:

  1. 提供外部展示的内容: 例如大多数回复的展示都是回复者+时间, 显然服务端不会一次返回给我们, 为什么我们不在Model中暴露一个借口叫replyText来组装这部分内容提供给UI层展示呢?
  2. 还是对外展示内容: 我们经常会对一个字符串有加粗或者其它颜色的展示需求, 为什么不在Model中提供一个attributedTitle的接口来对外提供需要一个AttributedString来展示这部分内容呢?
  3. 提供动态变化的内容高度: 服务端返回的内容不固定, 占用的高度也不固定, 在不使用自动布局的情况下, 为什么不在Model中计算高度呢? 特别是tableview中, cell是变高的情况, 因为cell的复用有可能导致一些高度也被复用的情况, 为了解决这种情况, 我看到不少人会缓存一个Array来保存高度, 而如果model中有能力直接返回高度就不需要在controller或者dataSource中写这一部分逻辑了, 且不用担心复用的副作用.
    ......

以上几点是我经常在Model中加入的逻辑, 这么做的好处是, 无论Model有什么变化都可以在Model内部解决, 比如发现自己有些属性名命名不太对, 有个展示的内容需要修改, 都不需要修改调用方的代码, 直接内部修改即可.

所以我个人是很乐意在Model中加入一部分业务逻辑代码的, 作为业务描述的Model, 多承载一些业务逻辑也未尝不可. 如果只是为了所谓的保持Model层的清洁, 那么我宁愿Model层与UI看上去有了那么一丝丝关系, 也不愿意把这些逻辑再加入到原本就需要承载更多逻辑的controller或者dataSource中了.

讨论

以上只是我个人的看法, 目前我一直在使用这样的Model在开发, 暂时没有遇到其它的副作用, 所以抛出这个问题想让大家一起来讨论这个做法的是否有所不足, 还有没有更进一步的地方.

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

推荐阅读更多精彩内容