1.真实项目架构介绍
先看看结果把,再看看到达这个结果的一些坑.
根据原始项目的组成,外加效仿的MJG(页面跳转用路由+服务调用采取协议映射服务类)的方式切分出6个基础组件:
KWBaseComponent //包含常用分类+常用UI控件+宏的基本组件
KWProtocolMediatorComponent //协议映射服务类中间件组件,内部就是KWProtocolMediator
KWRouterComponent //路由组件,内部就是MGJRouter
KWConfigComponent //配置文件组件
KWNetworkComponent //网络工具组件
KWMixAliComponent //融合Ali推送的组件
然后又切分出若干个业务组件:
KWLoginComponent
KWMineComponent
KWHomeComponent
等等
回归part1:练嘴
中所说的App组件化专注的问题
App组件化专注于两个问题:
1.各个页面之间的跳转问题. ==> KWRouterComponent(MGJRouter)
2.各个组件之间相互调用. ==> KWProtocolMediatorComponent(KWProtocolMediator)
2.制作pod没那么简单
在part3:演习
中,我们所写的制作pod的工程并不引用私有pod.但在真实pod实现组件化的时候是没那么简单了.
2.1 组件小工程角度
在写业务组件1小工程
的时候用到基础组件
,也就是说业务组件1小工程
内要用到基础组件的pod
.
在写业务组件1小工程
的用到业务组件2
的内容,也就是说业务组件1的小工程
内要用到组件2的pod
.
不是说好组件间不相互引用代码吗?[不相互引用]指的是[不直接引用]!组件间肯定存在着存在千丝万缕的关系,而这种关系用了pod做包装,实现了代码的物理隔断.
- 组件小工程引用其他私有组件pod注意点1
还记得podspec文件内部的s.dependency
字段吗?
s.dependency 'Masonry'
用到公有库要写,用到私有库也要写哦!
比如KWMineComponent
用到了公有库Masonry
,也用到了私有库KWLoginComponent
.那么s.dependency
字段就要写作:
s.dependency 'Masonry'
s.dependency 'KWLoginComponent'
- 组件小工程引用其他私有组件pod注意点2
还记得前文part3:演习
==>step4.1:校验
的命令pod lib lint
?
组件1小工程
引用组件2的pod
,组件1小工程
本身也要做pod的校验
,命令行就没有那么简单了!
pod lib lint --sources='https://git.oschina.net/pogongzhang/PGSpecs.git,https://github.com/CocoaPods/Specs' --allow-warnings --verbose --use-libraries
pod lib lint
后加上:
1.私有pod
所在私有pod仓库的地址
==>https://git.oschina.net/pogongzhang/PGSpecs.git
2.公有库地址
==>https://github.com/CocoaPods/Specs
--allow-warnings
--verbose
--use-libraries
这3句看情况加
2.2 壳工程角度
再看pod关系.png
,从壳工程(mainworkspace
)的角度看就是:你们背后是什么勾当,我不管.在我这,都是一级扁平化管理.
3.pod实现组件化 特有的具体的坑
3.1 组件小工程就不用写pch文件
日常开发中我们会将一些常用的宏,分类,类的头文件放在pch内,好全局一起用.现在写组件小工程就不用.因为校验时是只看贡献代码的,不会读pch的.如果你写了pch,并用到了pch的内容,校验时会报各种头文件找不到.
3.2 各种import头文件
因为不能写pch文件,所以要各种import头文件.
3.3 加载pod贡献的资源
前面已经讲过,pod内的图片
,xib
,storyboard
等资源文件必须要特别注意在podspec文件
内路径的配置.当然用到这些资源时,也是有要注意的地方.因为原始的开发方式,所有代码与资源都放在[NSBundle mainBundle]
内,而pod实现组件化的时候各个pod会有自己的Bundle
.
- 加载xib
原始开发加载xib
NSArray * nibs = [[NSBundle mainBundle]loadNibNamed:@"AnyInputView"owner:nil options:nil];
AnyInputView * inputView = [nibs objectAtIndex:0];
pod实现组件化加载pod内xib
NSArray * nibs = [[NSBundle bundleForClass:[加载资源的当前类]] loadNibNamed:@"AnyInputView"owner:nil options:nil];
AnyInputView * inputView = [nibs objectAtIndex:0];
- 加载图片
原始开发加载图片
UIImage * image = [UIImage imageNamed:@"any"];
pod实现组件化加载pod内图片
CGFloat scale_screen = [UIScreen mainScreen].scale;
NSString * path = nil;
NSString * name = @"any";
Class curClass = [加载资源的当前类];
if (scale_screen > 2.0){
NSString * fullname = [NSString stringWithFormat:@"%@@3x", name];
path = [[NSBundle bundleForClass:curClass] pathForResource:fullname ofType:@"png"];
}else{
NSString * fullname = [NSString stringWithFormat:@"%@@2x", name];
path = [[NSBundle bundleForClass:curClass] pathForResource:fullname ofType:@"png"];
}
UIImage * image = [UIImage imageWithContentsOfFile:path];
真刀真枪用pod实现组件化的时候会有各种坑,这里只列出了印象最深的.当然要掌握pod实现组件化看文章是绝对不够的,必须真刀真枪的干,自己去踩自己的坑.