Cocoa MVC框架模式笔记

一. MVC的概念

MVC全名是Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,一种软件设计典范,注意它是一种框架模式,而不是设计框架。

二. MVC的优点

MVC设计模式是用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。

三. Cocoa MVC元素

iOS中Model模型是封装应用程序的数据模型对象,并定义操控和处理该数据的逻辑和运算。

View视图对象是应用程序中用户可以看到的对象。视图对象的主要目的就是显示来自应用程序模型对象的数据,并使该数据可被编辑。在iOS开发中所有的控件,窗口都继承自UIView,UIView及其子类主要负责UI的实现,而UIView所产生的事件都可以采用委托的方式,交给UIViewController实现。

Controller控制器对象是应用程序的一个或者多个视图对象和一个或者多个模型对象之间的媒介。通过它视图了解模型对象的改变,反之亦然。控制器对象还可以为应用程序执行和协调任务,并管理其他对象的生命周期。对不同的UIView有相应的UIViewController,对应MVC中的C。

四. Cocoa MVC的主要特点

Cocoa MVC
  1. Controller是核心:Controller可以和View和Model主动通信。

  2. View是界面元素,分为两部分来理解:一是界面元素需要的数据部分,二是界面自身状态的变化阶段。

  3. View的功能就是显示界面元素不做逻辑处理,故View没有必要改变Model数据。故此不可以和Model通信.

  4. View通过点击事件,进行人机交互,因此View可以和Controller直接通信,通信方式为以下几种:

    4-1. 通过动作-目标模式,即Action,把View中的某个动作通过消息的方式映射到Controller上,实现通信(黄色箭头,红色箭靶),即View是Controller的一个属性,因此通过Action,控制器可以控制其他属性。

    4-2. 通过Delegate代理模式,把界面自身状态的变化,如didxxx,willxxx,shouldxxx等,通过消息的方式映射到Controller上,实现通信(黄色长线带有多箭头),如View把Action封装,虽然是Controller属性,但是Controller不能直接添加逻辑处理,因此需要实现Delegate协议,或者不同Controller的交互也需要使用Delegate。

    4-3. 通过DataSource的模式,把界面自身数据的状态和变化,如Count,Data等,通过消息的方式映射到Controller上,实现通信(黄色长线带有多箭头),最经典的就是常见的UITableView类。

  5. 虽然我们也可以通过KVO或者Notification的方式使View的某些消息定制投射到Controller上,但是并不主张如此,因为这就是将一部分处理逻辑放到了View里,这对MVC结构来说,是一个破坏。只是如果确实是必要的话,也是可以考虑使用的。

  6. Model是数据模型,初学者很容易把Model和Controller混在一起,而不把他们独立开来编写代码。为了更容易的重用和修改,建议还是独立出来比较好,这也是MVC结构的本质。

  7. Model不可以和View直接通信(黄色双实线)。

  8. Model一般不会和Controller直接通信,在和Controller的关系中,Model是处于被动通信的地位,Controller可以直接和Model通信,而Model往往通过KVO机制和Notification的方式把自身的变化投射给Controller(Model的黄色发射塔,Controller的黄色接收塔)。

五. Cocoa MVC的内部功能实现

View:
  1. 布局UI:就是将需要展示的界面显示到手机上。
  2. 监听点击事件:通过动作-目标模式,Delegate代理模式让控制器来处理逻辑。
  3. 实现DataSource:将模型数据注入到View中,以显示View。
Model:
  1. 实现数据的格式化。
  2. 利用Notification || KVO构造方法,和Controller通信,监听数据的变化。
Controller:
  1. 因为控制器本身有一个View属性,因此Controller需要做View的事情。
  2. 将SubView添加到Controller的View上。
  3. 实现SubView Action || Delegate协议,监听事件&&实现DataSource以展示SubView。
  4. 进行原始数据的加载:如应用HTTP协议加载后台数据,将原始数据注入到数据模型。

六. Cocoa MVC的弊端

  1. Controller和View耦合严重,导致Controller和View都很难做单元测试。

  2. 有很多不知道该放在哪的代码放在Controller,导致Controller过于臃肿,基本无法复用。

七. 针对重ViewController的瘦身方式

  • 将UITableView的DataSource分离到另一个类中。
  • 将数据获取和转换的逻辑分离到另一个类中。
  • 将拼装控件的逻辑,分离到另一个类中。
  • 将网络请求抽象到单独的类中。
  • 构建ViewModel。
  • 专门构造存储类。

参考资料:

iOS MVC框架模式
被误解的 MVC 和被神化的 MVVM
iOS 架构模式 - 简述 MVC, MVP, MVVM 和 VIPER (译)

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