写UIKit的代码, ViewController是离不开的.
本文试图讲讲它的基本知识, 不是很深入且有点杂乱, 供初级选手和跨技术栈同学参考.
What is a View Controller
iOS中的View Controller非常像Android中的Activity.
它负责用户界面的展示, 有一些生命周期的回调函数, 还和界面切换有关, 一个app中可以有一个或多个ViewController.
每一个ViewController都有一个single root view, 包含此ViewController的所有内容, 在页面上的所有View都会被加入到以这个root view为根的树形结构中去.
ViewController有一个view
属性, 代表最后返回的页面.
ViewController拥有所有的View, 管理和这些View相关的交互, 是离用户最近的第一层代码.
如何定义ViewController.
一般要继承UIViewController
.
如果你的页面主要是tableview或者collectionview也可以继承UITableViewController
或UICollectionViewController
.
ViewController的类型
ViewController的类型有两种:
- Content view controller: 管理一块view的内容. (大多数的ViewController都是这一种.)
- Container view controller: 作为一个container, 管理其中的child view controllers.
把每个child view controller的root view显示在container的view范围内. 可以每次只展示一个child, 也可以多个同时展示. UIKit中的UINavigationController
,UITabBarController
,UISplitViewController
,UIPageViewController
都是这种类型, 它们多数是为了不同界面之间的导航服务的.
生命周期回调
Controller的回调中最常用的是:
-
loadView()
: 用来设置根view属性, add views等. -
viewDidLoad()
, 可以用来做一些初始化的工作, 比如加载数据, add和remove views, 设置constraints等.
其他的回调方法名字也非常直白:
- viewWillAppear(): view绘制之前.
- viewDidAppear(): view绘制出来了.
- viewWillDisappear(): view马上要消失了.
- viewDidDisappear(): 已经消失了.
ViewController的职责
ViewController即MVC(Model View Controller)模式中的Controller.
如何管理View和数据的分离和交互是开发者自己的职责.
在简单的demo里, 如果你愿意, 一个ViewController就可以写完所有代码.
和Android一样, 我们会尽量把逻辑从ViewController(Activity)中拆分出去, 写出更加职责分明并且容易被测试的代码.
会有一些流行的模式, 比如MVVM什么的, 这里不展开讲了.
Scene, Window, ViewController
每一个Window都有一个root view controller, 是window最开始的内容.
展示一个新的view controller将会改变窗口内容.
它们之间的关系如图:
总结
iOS中的View Controller作为MVC模式中的Controller, 可以类比Android中的Activity:
- view属性返回页面内容.
- 有一些生命周期回调.
- 有一些各种各样的pattern为了让它承担的职责尽量得少.
(其实后端代码提供API的第一层也叫Controller, 所以有没有可能, 最开始设计UIKit的人是一个之前写后端的?)