Skip to content

Latest commit

 

History

History
87 lines (44 loc) · 3.97 KB

Readme_cn.md

File metadata and controls

87 lines (44 loc) · 3.97 KB

DecouplingKit

Twitter

Podfile

	platform :ios, '7.0'
	pod 'DecouplingKit', '~> 0.0.2'

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

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

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

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

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

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

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

使用

注册默认的DKService.plist服务列表

    [[DKServiceManager sharedInstance] registerLocalServices];

注册自定义路径的服务列表

    [[DKServiceManager sharedInstance] registerLocalServicesWithServiceConfigName:@"DecouplingKit.bundle/DKService"];

创建一个实例,如果这个Bussiness2ServiceProtocol对应的类实现了sharedInstance方法则生成单例,然后调用对应的实例方法

    id<Bussiness2ServiceProtocol> bussiness2 =[[DKServiceManager sharedInstance] createInstance:@protocol(Bussiness2ServiceProtocol)];
    
    NSDictionary *data =[bussiness2 fetchBussiness2DataWithName:@"DecouplingKit" age:@"1"];

创建一个类,然后调用对应类方法

   Class Bussiness2 = [[DKServiceManager sharedInstance] createClass:@protocol(Bussiness2ServiceProtocol)];

    [Bussiness2 callClassMethod];

创建自己业务线类的服务协议

@protocol Bussiness2ServiceProtocol <DKServiceProtocol>
@property (nonatomic,copy) NSString *name;
- (NSDictionary *)fetchBussiness2DataWithName:(NSString *)name age:(NSString *)age;
+ (void)callClassMethod;

@end

Licenses

All source code is licensed under the MIT License.