MVC和MVVM

来聊一聊我理解中的MVC和MVVM

MVC的定义:

MVC(Model View Controller)是构建iOS App 的标准模式,是苹果推荐的一个用来组织代码的权威范式。苹果甚至这么说,在MVC下,所有的对象被归类为一个Model,一个View,和一个Controller。

MVC各个部分负责的内容:

Model:根据APP文档,model包括数据和操作数据的业务逻辑
View:view通常是UIKit控或者UIKit控件的集合,不能直接引用model,并且视图本身没有任何业务逻辑
Controller:controller协调model和view之间的所有交互

MVC的工作流程及模型图:

首先,view将用户交互通知给controller,然后controller通过更新model来反应状态的改变,model成功持有数据后通知controller来更新他们负责的view。工作流程图如下:
MVC.png

MVC的优缺点

优点:
1>各施其职,互不干涉:三个层各施其职,其中一层改变对其它层影响较小。
2>有利于组件的重用:多个视图对应一个模型的能力等

缺点:
1>增加了系统结构和实现的复杂性:模型、视图与控制器分离,会增加结构的复杂性,并可能产生过多的更新操作,降低运行效率。
2>与控制器间的过于紧密的连接。
3>较差的可测试性:MVC并不鼓励测试人员编写单元测试。因为view controller混合了视图处理逻辑和业务逻辑,分离这些成分的单元测试成了一个艰巨的任务。
4、厚重的ViewController:由于各种原因使ViewController过于臃肿庞大。

MVVM的由来

MVC在在实际的应用中,由于个人理解的不同,容易出现以下各种情况

  • model层其实非常单薄,model从厚重的业务模型变为数据模型,model层的业务逻辑如本地数据库操作,数据处理等被拖入了controller。
  • 网络逻辑一般也放在controller中(因为网络使用异步,这样如果一个网络比持有它的model生命周期更长,事情将变得复杂。显然也不该将网络代码放在view中)
  • 相应逻辑:对各种用户事件做出响应及各种代理方法一般也在viewController里处理。

这就导致了controller变得厚重臃肿,让MVC变成了Massive View Controller,这时就出现了一种新的设计模式来替换MVC,就是MVVM

MVVM的定义:

MVVM(Model View ViewModel)衍生于MVC,它正式规范了视图和控制器紧耦合的性质,把 view和viewController正式联系在一起 ,我们把它们视为一个新的组件,并将controller中的业务处理逻辑,视图显示逻辑,网络逻辑,数据缓存逻辑等抽取出来,放入视图模型ViewModel中。

MVVM各个部分负责的内容:

Model:数据模型。ViewModel可以引用Model,反过来不行
View|view controller :不能直接引用model,引用ViewModel
viewModel:放置一些业务处理逻辑,视图显示逻辑,网络逻辑,数据缓存逻辑等(与其说是视图模型不如叫业务模型)

MVVM的工作流程模型:

首先,view|ViewController将用户交互通知给ViewModel,然后ViewModel通过更新model来反应状态的改变,model成功持有数据后通知ViewModel来更新他们负责的view。
MVVM.png

MVVM的优缺点:

优点:
1>低耦合性:view可以独立于model进行变化和修改,一个viewModel可以绑定到不同的view上。
2>可重用性:可以把一些视图逻辑放入viewModel中,让很多view重用这段视图逻辑
3>独立开发:开发人员可以专注于业务逻辑和数据的开发viewModel,设计人员可以专注于页面设计
4>可测试性:可以针对viewModel进行测试

缺点:
1>轻微的增加代码量,但总体上减少了代码的复杂度
2>数据绑定使得bug很难被调试。例如:界面异常,可能是view的代码有bug,可能是model的代码有问题。
3>对于大的项目,数据绑定和数据转化需要花费更所的内存

参考文档
http://www.cocoachina.com/ios/20170612/19500.html
http://www.cnblogs.com/brycezhang/p/3840567.html
http://www.mamicode.com/info-detail-989164.html

end:小编是很认真的写文哦,如果小编的文对您有用,一定要点“喜欢”哦!如果有问题欢迎评论

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

推荐阅读更多精彩内容