DecouplingKit - iOS 模块化解耦方案


MIT
iOS
C/C++

软件简介

Podfile

    平台:IOS,' 7.0 ' 
    荚' DecouplingKit ','〜> 0.0.2 '

DecouplingKit是一个用于模块之间解耦的方案。

当应用团队的人数增长到一定人数之后会分出业务线,这样就会就行模块化工作来隔离开各个业务线,以便让每个团队能够独立工作。通用的方案是采用cocoapods把业务代码分别到到各个仓库,一个业务线就是一个业务仓库,当然如果更大拆分力度的话,一个小模块就是一个cocoapods仓库。这样就对业务线就进行了物理路径的隔离,各个业务线就不能随便调用其他业务线的代码。不过对于一定要调用的话还是可以引入头文件来调用,所以本质上来讲根本没有解除各个业务仓库之间的耦合。

解除耦合其中一部分是业务线页面之间的跳转,现在流行的方案是通过路由器做。另外一部分很容易忽略就是业务线之间调用方法,属性等,所以就有了DecouplingKit这个中间层来解决这个问题.DecouplingKit之后的业务逻辑可以看下图。

DecouplingKit只有一个类DKServiceManager,用来加载服务列表DKService.plist,服务就是一个业务中类协议,里面有其他业务需要调用的方法,属性等.DKService.plist里面每一项有service和impl,service对于protocol,impl就是实现协议的类。

比如业务1需要调用业务2的方法,只需要DKServiceManager通过协议来找到对应业务2中的impl就可以了。其中协议会集中放在BussinessPublicService仓库,这里不依赖任何仓库,协议里面的方法对于入参和返回值都通过UIKit,Foundation等系统框架中类型,不需要自己的模型类。对于业务2的实现类只要实现对应的方法就好。

DKServiceManager既可以返回实例,也可以返回类方法,当然对于你如果实现了父协议DKServiceProtocol的sharedInstance方法,也可以返回单例。

DecouplingKit是基于BeeHive改造的,BeeHive包括AppDelegate管理和模块调用解耦两部分,DecouplingKit专注于模块调用解耦这部分,DecouplingKit只有一个类比BeeHive轻量,支持调用实例和类方法,属性。的另一种方式就是通过运行时来做,例如CTMediator,通过一个中间层(对应BussinessPublicService)来公布对应的接口,接口调用CTMediator(runtime)来实现,这也是一种非常好的方案。