引言
最近对组件化相关的知识比较感兴趣,翻看了好多大神的博客,算是对组件化有个大概的了解了。所谓的组件化,一方面是抽取私有Pod库,其实就是把我们的项目分成多个模块,例如基类模块、工具类模块、登陆模块、首页模块等等,然后把他们抽取成一个个私有Pod库,像平时利用cocopods导入三方库那样导入我们的这些私有库;另一个方面就是关于模块之间的通信问题,常常采用路由跳转。本文的主要目的是前者。
一. 公有Pod库的本质
公有Pod库大家应该都比较熟悉,项目中经常使用的三方库,如AFNetworking,Masonry,SDWebImage等都属于公有Pod库,任何一个开发者都可以把其导入自己的项目工程中进行使用。与之相对应的就是私有Pod库,它只能被有权限的人使用。其实公有和私有的区别不大,就是谁来管理.podspecs文件的问题,下面就说一下大家比较熟悉的公有Pod库的本质
- 远程索引库:存在一个公共的远程索引库,包含所有三方框架的.podspec文件,在.podspecs文件中包括了框架名,框架源码地址,用户名,描述等信息。
- 本地索引库:在安装pod,执行pod setup的时候,会将公共的远程索引库copy一份到本地,也即是公共的本地索引库。(可以查看此目录:/Users/xx/.cocoapods/repos, xx替换成你的电脑名,下同)
- 检索文件: 公共的本地索引库会另外生成一个检索文件,以键值对的形式,方便以后查找。( 可以查看此目录:/Users/xx/Library/Caches/CocoaPods)
- 导入三方库:执行pod install的时候,先去检索文件中查找,找到之后,在公共的本地索引库拿到框架源码地址进行导入。
二. 创建私有Pod库
上面已经提到了,公有Pod库是任何一个开发者都可以导入使用的,并且是能看到源码的,这显然不是我们想要的。我们的pod库应该是只能内部人员才能导入使用,所以我们应该把一个个模块抽取成私有的Pod库。
公有和私有Pod库的主要区别就是远程索引库不同,我们需要创建一个私有的远程索引库,用来管理私有库的.podspec文件,其他方面大同小异。
下面以Base模块为例,将其抽取成私有Pod库。说明一下:原项目名为ModuleDemo,位于桌面上。
1.创建私有的远程索引库
(1) 在coding.net上创建一个私有的仓库FERSpecs,克隆地址是:https://git.coding.net/jokin11/FERSpecs.git,FERSpecs就作为上面提到的私有的远程索引库。
(2) 终端执行下面命令,将私有的远程索引库copy到本地。
pod repo add FERSpecs https://git.coding.net/jokin11/FERSpecs.git
执行完毕后,在目录:/Users/xx/.cocoapods/repos 下会多出来一个FERSpecs文件夹,至此私有的索引库部分就完成了。
2.创建私有Pod组件库
(1) 打开终端,进入到桌面目录下,执行下面命令来创建一个名为FERBase的Pod库空模板。
pod lib create FERBase
依次输入下图信息进行基础配置:
配置完毕之后,Pod库空模板就创建成功了,系统会自动此模板。
(2) 在coding.net上创建远程仓库FERBase,克隆地址是:https://git.coding.net/jokin11/FERBase.git,在终端FERBase目录下执行下面命令,关联本地仓库到远程仓库。
git remote add origin https://git.coding.net/jokin11/FERBase.git
(3) 将原项目MoudleDemo中需要封装的Base模块,复制到 FERBase/FERBase/Classes中,同时将Base文件夹拖入项目的下图位置,顺便删除ReplaceMe文件,
pod spec lint
等待片刻,终端出现 FERBase.podspec passed validation
,则说明 FERBase.podspec 文件通过校验。
3.将FERBase.podspec文件加入私有的远程索引库
上面已经验证过 FERBase.podspec 文件没问题,接着就是要把 FERBase.podspec 文件添加到私有的索引库(也就是第一步中得到的索引库 FERSpecs),在终端执行下面命令:
pod repo push FERSpecs FERBase.podspec
上面命令对 FERBase.podspec 文件做了两个操作:一个是将其推送到私有的远程索引库,可以去 coding.net 的 FERSpecs仓库中查看;另一个是将其copy到私有的本地索引库,这个可以去目录:/Users/xx/.cocoapods/repos/FERSpecs 下查看到。
至此,Base模块抽取成私有的Pod库也就完成了,可以在终端执行pod search FERBase
来查询它,接下来就是在原项目中使用它了。
4.使用私有Pod库
在原项目的Podfile中,导入私有的Pod库的方式如下图
pod install
命令进行安装,安装完毕之后,可以看到Pods文件夹中已经有FERBase了,然后把原项目中的Base文件夹给删除掉即可。另外,公司内部其他成员在使用之前需要执行下面命令,将私有的远程索引库copy到本地,然后就可以正常使用了。
pod repo add FERSpecs https://git.coding.net/jokin11/FERSpecs.git
总结
在整个过程中,需要到git服务器上创建两个仓库,一个作为索引库,一个作为pod组件库;接着就是创建模板并配置.podspec文件;然后就是让索引库管理.podspec文件,之后就是使用了,如果清楚了这几步,对于抽取私有Pod库应该很得心应手。