Fork me on GitHub

iOS中UIViewController完美瘦身

对于UIViewController瘦身是一个老生常谈的问题,现在也有比较多的架构来实现此效果,比如MVVM等等。不过这次我们是对于传统的MVC架构设计实现完美的瘦身。此方法也完全不妨碍在此基础上使用MVVM等其他方法瘦身。

情景

首先让我们看一下我们要做的界面效果

看着界面不是很难,最上边是二维码扫描;中间输入一些信息,数字1、2、3是按钮点击网络请求然后弹出选择界面供用户选择;最下边历史数据。

其实写下来交互非常的多,接口非常多,业务逻辑也非常的复杂,
传统MVC下来整个.h文件估计至少1500行以上。

瘦身思路

通过上图中的两根红色实现,我们将此界面划分成三部分。则声明四个UIViewController:
分别为:

  • ScanViewController 扫描功能
  • InfoInputViewController输入信息
  • HistoryViewController历史数据
  • MyViewController组装功能
    MyViewController中我们进行组装,并处理一些非业务事件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
self.myScanVC = [[ScanViewController alloc] init];
[self addChildViewController:self.myScanVC];
[self.view addSubview:self.myScanVC.view];
[self.myScanVC didMoveToParentViewController:self];

self.myInforInputVC = [[InfoInputViewController alloc] init];
[self addChildViewController:self.myInforInputVC];
[self.view addSubview:self.myInforInputVC.view];
[self.myInforInputVC didMoveToParentViewController:self];

self.myHistoryVC = [[HistoryViewController alloc] init];
[self addChildViewController:self.myHistoryVC];
[self.view addSubview:self.myHistoryVC.view];
[self.myHistoryVC didMoveToParentViewController:self];

通过此方法,我们第一步已经成功降低了耦合度,而且在项目中还有更大的一个优点就是ScanViewControllerHistoryViewController两个类可以达到复用的效果,其他功能也需要这两个功能,所有的业务逻辑全部在InfoInputViewController


由于InfoInputViewController中也有非常多的业务逻辑而且以按钮点击之后开始响应为主。
现在看一下我们的点击事件有多简洁:

1
2
3
4
- (IBAction)actionClick:(UIButton *)sender {
[self.view endEditing:YES];
[self.actionsContext doActionWithLevel:sender.tag];
}

是的没有任何判断,而且我们把所有的业务逻辑均封装在了一个一个的Action中。
下午是我们类结构的设计

以上设计思路其实我有单独写过《设计模式之感悟和实践(二)》
具体代码文章中也有。

通过此方法既消除了if…else的判断,同时每个点击时间的业务逻辑也就行了单独的封装。


通过以上两个方法的结合成功了将“UIViewController”瘦的简直不能再瘦了!!

0%