原创 2017-05-09
关键点:
- 公有Pod仓库创建
- 私有Pod的创建规范
- 如何开发及部署你的pod
这里仅以公司一个示例项目列举部分规范,后期会持续修改,如果你也在做这方面的事情,并且有更多我暂时没有说到的建议请联系我的邮箱,不胜感谢!
公有Pod仓库创建
相信你已经通过组件化开发之-Cocoapods使用及创建发布自己的Pod了解到了如何创建一个共有仓库,创建公有仓库时,并没有什么规范,但是有一个建议是你创建出来的项目目录按照如下比较好(这些是参考的cocoapods官方网站示例):
- 包含一个Pod
- 包含一个Example目录,介绍使用方法
- Pod 目录目录层次下包含一个Classes、Resources(资源文件再继续分层级)
如下是我的一个公有pod及现有可以使用的pods
私有Pod的创建规范
我们要创建私有仓库,那么在选用私有仓库时可以使用github的私有仓库(当然这是需要付费的),抑或在自家服务器上搭建一个,我是比较倾向于第三个使用码云。
假设你已经有了一个码云账号,这里我们还是先创建一个组织吧,可以以你团队的名称,或者其他任何你喜欢的名称(因为有可能你们是几个团队使用的是一个码云账号,为了避免repository过多管理问题,或者觉得看着不舒服)
-
创建了一个组织:
-
接下来就是创建你的私有Repository
-
添加一个Pod
建议你的私有pod名称可以是你公司的名字,或者一个项目的名字,方便以后管理, 这里我以公司名称 sefon 为例
-
接下来就是创建组件相关的Repository
这里我参考的是cocoapod官方提供的一个私有仓库创建示例:采用私有repo名称-组件名称,比如你在添加一个私有repo时使用的是Sefon,而这里你需要开发一个用户User相关的组件,那么Sefon-User就应该作为你在git上的repository名称。
-
创建.podspec
在上面提到的我们仓库名称为Sefon-User,在这里我们我们的pod是略微不同,我们需要使用Sefon+User这个名称,这不是强制性的,但是需要你这么做,保持整改项目的规范(这里也是参考cocoapod官方提供的私有仓库创建示例)
-
完善目录结构
在创建的私有pod中,这里需要:- 包含一个使用.swift-version (如果使用的是Swift开发必须)
// 在你的.podspec所在目录执行 $ echo "swift版本" > .swift-version // 比如我使用的是3.0
$ echo "3.0" > .swift-version
- 包含Pod所有的引用以及一个Exmaple - Pod包含一个Classes文件夹(必须) - Pod包含一个Resources文件夹(非必须,存在资源文件添加) - Pod目录层级下Resources中将资源需要分离开来,如:Fonts、Images、Sounds等
- 包含一个使用.swift-version (如果使用的是Swift开发必须)
如何开发及部署pod
-
项目采用MVVM开发模式,请在你的项目中至少包含着几个文件夹Model、View、ViewModel
-
开发完成后,确认通过测试,现在可以将你所依赖的class、资源等拷贝进我们上面提到的Pod 目录所对应的层级结构中:
修改.podspec
参照官方Guides以及组件化开发之-Cocoapods使用及创建发布自己的Pod 修改你的.podspec
特别说明:
如果你的组件使用到了第三方的Podfile,那么在你构建你自己的Pod时请你将其添加至你的.podspec中的s.dependency, 这里会影响到后续的插件化开发,以及通过Jenkins实现持续构建的问题,以及提供SDK供第三方自行开发业务组件,具体细节将在后续补充