[Android开发学iOS系列] ViewController

iOS ViewController【[Android开发学iOS系列] ViewController】写UIKit的代码, ViewController是离不开的.本文试图讲讲它的基本知识, 不是很深入且有点杂乱, 供初级选手和跨技术栈同学参考.
What is a View ControlleriOS中的View Controller非常像Android中的Activity.
它负责用户界面的展示, 有一些生命周期的回调函数, 还和界面切换有关, 一个app中可以有一个或多个ViewController.
每一个ViewController都有一个single root view, 包含此ViewController的所有内容, 在页面上的所有View都会被加入到以这个root view为根的树形结构中去.
ViewController有一个view属性, 代表最后返回的页面.
ViewController拥有所有的View, 管理和这些View相关的交互, 是离用户最近的第一层代码.
如何定义ViewController.一般要继承UIViewController.
如果你的页面主要是tableview或者collectionview也可以继承UITableViewControllerUICollectionViewController.
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将会改变窗口内容.
它们之间的关系如图:
[Android开发学iOS系列] ViewController

文章插图
图片来源
总结iOS中的View Controller作为MVC模式中的Controller, 可以类比Android中的Activity:
  • view属性返回页面内容.
  • 有一些生命周期回调.
  • 有一些各种各样的pattern为了让它承担的职责尽量得少.
(其实后端代码提供API的第一层也叫Controller, 所以有没有可能, 最开始设计UIKit的人是一个之前写后端的?)
References
  • ViewController Programming Guide for iOS
  • Managing content in your app’s windows
  • UIViewController

    经验总结扩展阅读