模型-視圖-控制器(Model-View-Controller,MVC)是Xerox PARC在20世紀(jì)80年代為編程語(yǔ)言Smalltalk-80發(fā)明的一種軟件設(shè)計(jì)模式暖侨,至今已廣泛應(yīng)用于用戶(hù)交互應(yīng)用程序中克蚂。在iOS開(kāi)發(fā)中MVC的機(jī)制被使用的淋漓盡致集绰,充分理解iOS的MVC模式十电,有助于我們程序的組織合理性。

模型對(duì)象
模型對(duì)象封裝了應(yīng)用程序的數(shù)據(jù)肥橙,并定義操控和處理該數(shù)據(jù)的邏輯和運(yùn)算魄宏。例如,模型對(duì)象可能是表示游戲中的角色或地址簿中的聯(lián)系人存筏。用戶(hù)在視圖層中所進(jìn)行的創(chuàng)建或修改數(shù)據(jù)的操作宠互,通過(guò)控制器對(duì)象傳達(dá)出去味榛,最終會(huì)創(chuàng)建或更新模型對(duì)象。模型對(duì)象更改時(shí)(例如通過(guò)網(wǎng)絡(luò)連接接收到新數(shù)據(jù))予跌,它通知控制器對(duì)象搏色,控制器對(duì)象更新相應(yīng)的視圖對(duì)象。
視圖對(duì)象
視圖對(duì)象是應(yīng)用程序中用戶(hù)可以看見(jiàn)的對(duì)象匕得。視圖對(duì)象知道如何將自己繪制出來(lái)继榆,并可能對(duì)用戶(hù)的操作作出響應(yīng)巾表。視圖對(duì)象的主要目的汁掠,就是顯示來(lái)自應(yīng)用程序模型對(duì)象的數(shù)據(jù),并使該數(shù)據(jù)可被編輯集币。盡管如此考阱,在 MVC 應(yīng)用程序中,視圖對(duì)象通常與模型對(duì)象分離鞠苟。
在iOS應(yīng)用程序開(kāi)發(fā)中乞榨,所有的控件、窗口等都繼承自 UIView当娱,對(duì)應(yīng)MVC中的V吃既。UIView及其子類(lèi)主要負(fù)責(zé)UI的實(shí)現(xiàn),而UIView所產(chǎn)生的事件都可以采用委托的方式跨细,交給UIViewController實(shí)現(xiàn)鹦倚。
控制器對(duì)象
在應(yīng)用程序的一個(gè)或多個(gè)視圖對(duì)象和一個(gè)或多個(gè)模型對(duì)象之間,控制器對(duì)象充當(dāng)媒介冀惭≌鹦穑控制器對(duì)象因此是同步管道程序,通過(guò)它散休,視圖對(duì)象了解模型對(duì)象的更改媒楼,反之亦然∑萃瑁控制器對(duì)象還可以為應(yīng)用程序執(zhí)行設(shè)置和協(xié)調(diào)任務(wù)划址,并管理其他對(duì)象的生命周期。
控制器對(duì)象解釋在視圖對(duì)象中進(jìn)行的用戶(hù)操作限府,并將新的或更改過(guò)的數(shù)據(jù)傳達(dá)給模型對(duì)象夺颤。模型對(duì)象更改時(shí),一個(gè)控制器對(duì)象會(huì)將新的模型數(shù)據(jù)傳達(dá)給視圖對(duì)象谣殊,以便視圖對(duì)象可以顯示它拂共。
對(duì)于不同的UIView,有相應(yīng)的UIViewController姻几,對(duì)應(yīng)MVC中的C宜狐。例如在iOS上常用的UITableView势告,它所對(duì)應(yīng)的Controller就是UITableViewController。
Model和View永遠(yuǎn)不能相互通信抚恒,只能通過(guò)Controller傳遞咱台。
Controller可以直接與Model對(duì)話(huà)(讀寫(xiě)調(diào)用Model),Model通過(guò)Notification和KVO機(jī)制與Controller間接通信俭驮。
Controller可以直接與View對(duì)話(huà)回溺,通過(guò)outlet,直接操作View,outlet直接對(duì)應(yīng)到View中的控件,View通過(guò)action向Controller報(bào)告事件的發(fā)生(如用戶(hù)Touch我了)。Controller是View的直接數(shù)據(jù)源(數(shù)據(jù)很可能是Controller從Model中取得并經(jīng)過(guò)加工了)混萝。Controller是View的代理(delegate),以同步View與Controller遗遵。