随着客户端开发项目的复杂度越来越高,组件化是一个必然的过程;从最初蘑菇街基于短链方案,到后来 protocol方案,再到后来的CTMediator 大概经历了这么三次发展的经历
今天文章主要讲关于CTMediator实现
demo地址:
将上面三个项目下载到同一目录下,cd到BBVoIPSDKDemo中,执行pod install,然后run即可
总体步骤:
1:创建私有库(BBVoIPSDK),具体可参考:pod私有库搭建
2:创建私有库的Catetory (BBVoIPSDKCategory),在此项目的.podspec中增加s.dependency 'CTMediator'
在Category项目中,创建一个CTMediator扩展类,eg:CTMediator+BBVoIPSDK.h,CTMediator+BBVoIPSDK.m
这个类是实现组件间交互的关键类
至此:BBVoIPSDK和BBVoIPSDKCategory工程就准备好啦
3:创建壳工程(即:主工程),
在主工程的Profile下添加:
pod 'BBVoIPSDKCatetory' , :path => '../BBVoIPSDKCatetory'
pod 'BBVoIPSDK', :path => '../BBVoIPSDK'
注意:实验demo所以使用的是本地引入,实际发布项目修改为具体版本即可
pod install
4:在业务组件中,添加Target-Action
注意:图三种的方法名后缀与图一中定义的方法名要一致
即:Action_talkViewController 下划线后面的名称与图一定义的名称一致,方可找到方法
总结:
组件化开发是一个高效的工作方式
核心思想:
创建类似BBVoIPSDKCategory的类供外部调用,创建一个业务组件
其中 performTarget: action: 方法是 CTMediator 组件的方法, 他主要是通过这个方法找到对应的业务组件中的文件名也是类名(Target_BBVoIPSDK)和方法名(Action_talkViewController),kCTMediatorTargetBBVoipSDK为类名, kCTMediatorActionBBVoipSDKTalkViewController方法名
业务组件和分类组件的生成规则也是严格按照CTMediator组件的规则来创建, 即Target_AAA和CTMediator (AAA)的方式, 业务组件中的方法名称的生成规则为Action_BBB
CTMediator内部业务逻辑就会寻找调用Target_AAA的类和你传过来的方法名称BBB来寻找对应的业务组件和方法,而这个AAA一般就是你拆分组件的前缀名称, 例如示例中就是BBVoIPSDK,
分类一般一个组件中BBVoIPSDK_Category和业务组件BBVoIPSDK为同一人所完成, 那么提供给同事时, 只要组件内部遵守CTMediator的命名规则确保分类能调用到业务组件中的方法, 只要把BBVoIPSDKd_Category中对外的方法提供给对接同事即可