从代码拆分到 VIPER 架构演化

2015-09-03 02:38:43 +08:00
 cralison

减小焦点,叠加信息

《 ViewController 代码拆分实践》
http://www.jianshu.com/p/f30438b89bc6

上篇文章里,我们把 ViewController 按视图、网络请求、本地存储、页面跳转四层进行拆分。

拆分之后, ViewController 的代码足够少,而因为是采用协议对象的方式进行拆分,后续的可维护性和可扩展性又足够高。

今天,我们多走一步:实现 VIPER 架构。

我们看看拆分代码后的 ViewController.h 。

#import "ViewInterface.h"
#import "APIInterface.h"
#import "StoreInterface.h"
#import "RouteInterface.h"

@interface ViewController : UIViewController<ViewInterface>

@property (nonatomic, weak ) id<ViewInterface> viewModel;
@property (nonatomic, weak ) id<APIInterface> apiHandle;
@property (nonatomic, weak ) id<StoreInterface> storeHandle;
@property (nonatomic, weak ) id<RouteInterface> routeHandle;
@end

引用 4 个 Interface ,声明了 4 个协议对象。把 ViewControler 里的 4 个层次的事件消息通过 4 个协议对象进行分发。

4 个,我们还是嫌太多。如果只有 1 个就好了,这样我们做 ViewController 消息分发时就不用考虑向哪个协议对象分发了。

说干就干,把 4 个协议对象合成 1 个:

@interface ViewController : UIViewController<ViewInterface>

@property (nonatomic, weak ) id<ViewInterface,APIInterface,StoreInterface,RouteInterface> eventHandle;
@end

把原来由 4 个协议对象分别引用方法的地方,全部改为由 eventHandle 引用。

self.hotList = [self.eventHandle unarchive];
[self.eventHandle loadData];
return [self.eventHandle configureWithCell:cell data:data];
[self.eventHandle pushDetailInterfaceFromViewController:self detailData:detailData];
[self.eventHandle archiveWithObject:self.hotList];

把 4 个 Interface 的引用,合并成一个:

#import <UIKit/UIKit.h>

#ifndef ViewControllerSplit_EventInterface_h
#define ViewControllerSplit_EventInterface_h
@protocol ViewInterface <NSObject>

@optional
- (void )hotListWtihData:(NSArray *)data;
- (UITableViewCell *)configureWithCell:(UITableViewCell *)cell data:(NSDictionary *)data;
@end

@protocol APIInterface <NSObject>

@optional
- (void )loadData;
@end

@protocol StoreInterface <NSObject>

@optional
- (id )unarchive;
- (void )archiveWithObject:(id )object;
@end

@protocol RouteInterface <NSObject>

@optional
- (void )pushDetailInterfaceFromViewController:(UIViewController *)viewController detailData:(NSDictionary *)detailData;
@end
#endif

于是 ViewController.h 被简化到了极致:

#import <UIKit/UIKit.h>
#import "EventInterface.h"

@interface ViewController : UIViewController<ViewInterface>

@property (nonatomic, weak ) id<ViewInterface,APIInterface,StoreInterface,RouteInterface> eventHandle;
@end

我们新建一个实际处理四层消息的类,名字为 Presenter :

#import <Foundation/Foundation.h>
#import "EventInterface.h"

@interface Presenter : NSObject<ViewInterface,APIInterface,StoreInterface,RouteInterface>
@end

至此,我们完成了土制代码拆分到高大上的 VIPER 架构演化的全部过程。

VIPER ,无非是通过 Presenter 统一转发 ViewController 的消息,使 ViewController 从臃肿和紧耦合中解脱出来,让 ViewController 更小更少依赖,方便维护、复用。

Presenter 收到 ViewController 转发过来的消息,分别向 Interactor (API, Store )、 WireFrame (View, Route )转发处理。

本质上都一样:通过消息转发,把代码扔出本类,进行黑箱复用。

后记(下面以聊家常为主,没时间没兴趣的朋友请直接忽略):

准确地说,我前天晚上非常开心。因为我从《无头骑士异闻录×2 》想到了:只有深钻才能摆脱无聊。

我们很害怕生活很普通。普通得自己像没在这个世界存在过一样。但如果我们继续肤浅、表面地活着,不管我们多么有钱有势,还是无法摆脱恐怖的无聊感。

而那些但凡有任何一件事情可以去深钻的人,却不会有这样的无聊感,他们只有深钻精彩的忙碌感。只擅长这个啊。时间不够用不够用啊。

从此,我努去让自己把关注的焦点一再减少缩小,然后把所有时间精力人脉全部投入到这个足够小的点上。通过高强度的信息轰炸,消灭掉这一个点。彻底解决掉它。

随着我越钻越深,自然会有越来越多有趣的人和事会找到我。那时,我只需要随随便便地忙碌着,生活就会被得足够有趣。

我自己做了一家三口焦点表,没有这方面经验的朋友可以参考一下:

我:

老婆| 儿子| 健身| 读书| 编程

日语| 玩具| 腹腰| 算法| 项目

老婆:

老公| 儿子| 健身| 读书| 手工

日语| 玩具| 瑜珈| 天文| 科技

儿子:

妈妈| 爸爸| 健身| 读书| 外出

日语| 玩具| 跑步| 科技| 艺术

世界上的所有事情,无论什么基础,无论什么背景,无论什么环境,通通全部都必须按两步去解决:

1 、减小焦点

2 、叠加信息

今天想明白一件事情:粉丝群的功能。
粉丝群只有一个功能:粉丝帮助群主思考,粉丝帮助群主做事。

没错,我建粉丝群,不是为了帮任何人,而只是希望能得到别人的帮助。如果你觉得我值得你帮,欢迎进来。如果你只希望我或我的粉丝群友帮你,请你滚开,我踢不留情:)

iOS 开发,读书狂魔
清醒疯子利炳根粉丝群:1470435289

长久以来,我一直害怕别人觉得我是新手、太弱。其实没关系,我现在确实还很新手很菜很弱啊。但,不管怎么样,我会继续努力啦。

分享一部纪录片《中国的秘密》
http://qianmo.com/u/6292/5

1882 次点击
所在节点    iDev
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/217996

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX