iOS VIPER架构简析

在建筑学领域,有这样一句话:我们虽然在营造建筑,但建筑也在重新塑造我们。作为一名开发人员,如果你曾认真的去做过架构相关的东西,对这句话必然有着深刻体会。一个好的架构,不仅可以让一款产品成功的投入使用,还可以让产品具有良好的可维护性。这篇文章,主要介绍一种被称为VIPER的架构,并基于swift的特性去做相应的设计。

VIPER是视图(View)、交互器(Interactor)、展示器(Presenter)、实体(Entity)和路由(Routing)的首字母缩写。

视图:根据展示器的要求显示界面,并将用户输入反馈给展示器;这里不仅仅是指UIView或其子类,还包括UIViewController,主要负责一些视图的显示、布局、用户事件的接收;

交互器:包含由用力指定的业务逻辑;

展示器:包含为显示(从交互器接受的内容)做的准备工作的相关视图逻辑,并对用户输入进行反馈(从交互器获取新数据);

实体:包含交互器要使用的基本模型对象;

路由:包含用来描述屏幕显示和显示顺序的导航逻辑;

这种分隔形式遵循单一责任原则。交互器负责业务分析的部分,展示器代表交互设计师,而视图相当于视觉设计师。

在VIPER的实际应用中,组件之间可以以任意顺序来实现,但在个人的实现过程中,经过反复的理论推敲和实践,推荐使用这样的顺序来进行实现。

交互器

交互器的任务是根据业务逻辑来操纵模型对象(即实体),它的工作应当独立于任何用户界面,只对外暴露相应的接口接口;同样的交互器应当可以同时运用于iOS应用或 OS X应用中。交互器主要包含逻辑,因此非常容易使用TDD进行开发。故此,在实现交互器的时候,只需要是一个普通的NSObject即可,在其内部处理对应的业务逻辑,并向外提供简明的交互接口。

实体

实体是被且仅被交互器操作的模型对象,此处再次声明交互器的作用:处理所有的业务逻辑。在swift环境下,实体可以通过NSObject、Struct来实现,如果使用了Core Data,最好将托管对象保持在数据层之后。

展示器

在我实现VIPER的过程中,展示器也是基于NSObject来实现的。展示器收集来自用户的行为交互,在合适的时候更新用户界面并向交互器发送业务请求。在我们实现的过程中,展示器是整个 VIPER 架构的枢纽(也有人偏向于以 Interactor 为枢纽,通过具体实践,个人推荐使用 Presenter),主要功能是各类消息的转发和界面路由,如:Presenter 从 View 获得用户事件的消息,并发送给 Interactor ,Interactor 进行相应逻辑处理后,反馈消息给 Presenter,Presenter 将消息再反馈到 View 上。

视图

视图一般处于一种被动接受的状态,被动接收来自用户的行为交互,被动接收由展示器传递来的消息(如展示器下发的需要展示的内容)。展示器不知道视图中存在的控件,只负责告诉视图在合适需要显示什么样的内容,内容如何显示由视图自行处理。

路由

在实现路由的过程中,我尝试过两种方案,一种是网上大多数VIPER架构文章中介绍的wireframe(线框),另一种是基于URL的router。这两种方案都实现以下两个目的:

建立路由中间件,所有的界面跳转由中间件处理;

所有界面跳转可交由后台控制,APP做好路由节点注册;

根据我们团队的实际情况和业务需求,我们最终选择使用基于URL的路由形式(命名为:GSRouter)。在此基础上,参考了HandyJson的实现思想,我们为GSRouter加入了参数自动解析功能,在此,对HandyJson的作者表示衷心的感谢。

在实现路由模块的过程中,不管是线框还是GSRouter,都是去注册目标vc的生成过程(以block的形式)。简单来说就是,当路由中间件发现你要跳转到某个vc的时候,就去调用这个vc对应的block,在block中初始化该vc,然后将初始化好的vc对象回调出来,再根据跳转形式(present/dismiss or push/pop)进行跳转,同时,还可以为跳转配置对应的动画效果。当然,如果你使用的是storyboard,可以运用建造者模式写一个通用的vc对象生成方法(builder),不需要再经过block,然后为UIViewController添加一个参数自动解析方法,这样你的路由模块就已经具有了基本的功能了。

以上是对VIPER的一个大致介绍,以及我个人在实现VIPER架构过程中的一些感悟和理解,由于公司的保密要求,暂时未能提供小demo,在后面时间丰裕的时候,我会整理一个小demo并上传到github,以供大家参考。如果上述表述中有任何不合适或理解不到位的地方,请大佬们批评指正。

最后,非常感谢您的耐心阅读!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,692评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,482评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,995评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,223评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,245评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,208评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,091评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,929评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,346评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,570评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,739评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,437评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,037评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,677评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,833评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,760评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,647评论 2 354

推荐阅读更多精彩内容