[Android开发学iOS系列] ViewController

  • Post category:IOS

iOS ViewController

写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将会改变窗口内容.

它们之间的关系如图:
ViewController and Window

图片来源

总结

iOS中的View Controller作为MVC模式中的Controller, 可以类比Android中的Activity:

  • view属性返回页面内容.
  • 有一些生命周期回调.
  • 有一些各种各样的pattern为了让它承担的职责尽量得少.

(其实后端代码提供API的第一层也叫Controller, 所以有没有可能, 最开始设计UIKit的人是一个之前写后端的?)

References