前言
目前公司有多个app项目,其中多个项目之间有很多模块是共用的,区别只是参数或几个配置的不同。比如网络层工具、三方分享登录、常用category、常用工具栏等。
本文将讲解创建私有组件库的流程,私有组件库是公司内部私有仓库,可以使用pod引用,但是在pod search是搜索不到的。
新建组件
1.从头开始创建,可以通过 pod lib create 组件名 来创建工程。下面演示下创建MyDemo组件:
cd 项目路径下
pod lib create MyDemo
之后会询问5个问题:
1.创建什么平台的项目?iOS/macOS,直接回车默认选择iOS平台
2.使用什么开发语言?Swift/Objc,输入Objc回车
3.需不需要创建一个测试例子?直接回车默认需要
4.需不需要包括一个测试框架?输入None,不需要
5.是否基于View测试?输入NO,不需要
6.项目的前缀是什么?输入自己的前缀回车
完成后会默认执行pod install,并自动打开测试项目。
看下项目的目录结构
.
├── Example
│ ├── MyDemo
│ │ ├── Base.lproj
│ │ ├── Images.xcassets
│ │ │ └── AppIcon.appiconset
│ │ └── en.lproj
│ ├── MyDemo.xcodeproj
│ │ ├── project.xcworkspace
│ │ └── xcshareddata
│ │ └── xcschemes
│ ├── MyDemo.xcworkspace
│ │ └── xcshareddata
│ ├── Pods
│ │ ├── Headers
│ │ ├── Local\ Podspecs
│ │ ├── Pods.xcodeproj
│ │ │ └── xcuserdata
│ │ │ └── mawenshuai.xcuserdatad
│ │ │ └── xcschemes
│ │ └── Target\ Support\ Files
│ │ ├── MyDemo
│ │ ├── Pods-MyDemo_Example
│ │ └── Pods-MyDemo_Tests
│ └── Tests
│ └── en.lproj
├── MyDemo
│ ├── Assets
│ └── Classes
└── _Pods.xcodeproj -> Example/Pods/Pods.xcodeproj
2.我们需要将要组件化的代码文件放在MyDemo/MyDemo/Classes
下,将资源文件(图片、plist等)放在MyDemo/MyDemo/Assets
下。
3.在Example
测试项目文件夹下执行pod update
更新pod。只要更新了Assets或Classes下的内容,都需要执行pod update。
4.打tag:组件测试稳定后,打上正式的tag。tag统一只打数字就可以了,比如0.0.1、0.0.2。
5.开发测试完成后,更新podspec文件内容。
Pod::Spec.new do |s|
s.name = 'MyDemo'
s.version = '0.1.0'
s.summary = 'A short description of MyDemo.'
s.description = <<-DESC
TODO: Add long description of the pod here.
DESC
s.homepage = 'https://github.com/mws100/MyDemo'
# s.screenshots = 'www.example.com/screenshots_1', 'www.example.com/screenshots_2'
s.license = { :type => 'MIT', :file => 'LICENSE' }
s.author = { 'mws' => 'email@163.com' }
s.source = { :git => 'https://github.com/mws100/MyDemo.git', :tag => s.version.to_s }
s.ios.deployment_target = '8.0'
s.source_files = 'MyDemo/Classes/**/*'
s.resource_bundles = {
'MyDemo' => ['MyDemo/Assets/*.png']
}
# s.public_header_files = 'Pod/Classes/**/*.h'
# s.frameworks = 'UIKit', 'MapKit'
s.dependency 'AFNetworking', '~> 2.3'
end
6.更新readme
文件。参考公司内制定的标准模板。
7.此时代码是在本地Git仓库的管理下,我们需要将其push到远程仓库。
git add --all
git commit -m "描述"
git remote add origin https://test.com/MyDemo.git
git push origin master
git push --tags
8.在正式项目中通过tag的方式引入
pod 'MyDemo', :git => "https://test.com/MyDemo", :tag=>'0.0.1'