基于CocoaPods的iOS项目模块化实践
什么是CocoaPods?
CocoaPods is a dependency manager for Swift and Objective-C Cocoa projects. It has over ten thousand libraries and can help you scale your projects elegantly. - 摘录自CocoaPods.org
在CocoaPods出现之前,iOS项目中引用第三方库的方式是非常原始的,要么是把源代码拷贝到主工程中,要么是通过静态库引入.a文件,然后还要修改一系列的build settings。后续的第三方库的升级也是个枯燥乏味的事情,总之如果你的iOS项目目前还是这样管理第三方库,那么你们还处在石器时代。
CocoaPods通过集中式的管理,可以非常有效的管理第三方库,甚至可以用于大型项目的模块化管理,非常优雅高效的解决iOS项目中的依赖管理。
安装CocoaPods
CocoaPods是一个Ruby Gem,因为直接访问RubyGem速度非常慢,建议先替换成淘宝镜像
$ gem sources --remove https://rubygems.org/
$ gem sources -a https://ruby.taobao.org/
安装CocoaPods
$ sudo gem install cocoapods
管理第三方库
创建Podfile
在项目根目录下创建Podfile,下面是一个Podfile的例子 (详情可以参考http://guides.cocoapods.org/syntax/podfile.html#podfile):
platform :ios, '9.0' target "MyApp" do
pod 'ObjectiveSugar', '~> 0.5' target "MyAppTests" do
pod 'OCMock', '~> 2.0.1'
end
end
platform: 可以指定平台的信息和deployment target的版本
target: 可以根据不同的target来引入不同的pod
pod: 引入依赖库
pod 'SSZipArchive' -- 引入最新版本
pod 'Objection', '0.9' -- 引入特定的版本
pod 'Objection', '>0.9'> -- 任何大于0.9的版本
pod 'Objection', '>=0.9'> -- 任何大于等于0.9的版本
pod 'Objection', '<0.9'> -- 任何小于0.9的版本
pod 'Objection', '<=0.9'> -- 任何小于等于0.9的版本
pod 'Objection', '~>0.9'> -- 任何介于0.9到1.0的最新版本,不包含1.0
pod 'AFNetworking', :path => '~/Documents/AFNetworking' -- 使用本地路径引入
pod 'AFNetworking', :git => 'https://github.com/gowalla/AFNetworking.git', :tag => '0.7.0' -- 使用git库引入
pod 'JSONKit', :podspec => 'https://example.com/JSONKit.podspec' -- 使用外部的podspec来引入
安装Pods
安装pods
$ pod install
更新pods
$ pod update
install和update的区别:假如使用 pod 'SVProgressHUD',没有指定版本。使用pod install,如果Pods中存在SVProgressHUD,则直接使用。使用pod update,则会保证更新SVProgressHUD到最新版本。
install或update速度通常很慢,因为每次执行的时候都需要同步一下CocoaPods Specs,这个有几百兆的大小,同步一次非常耗时。所以如果你使用的第三方库并不是经常更新,则不用经常更新那个Specs库。可以使用以下命令:
$ pod install --verbose --no-repo-update
$ pod update --verbose --no-repo-update
执行完install或者update命令后,就可以使用.xcworkspace打开项目。
使用CocoaPods管理私有库
大型项目模块化管理
随着iOS APP越来越复杂,功能越来越多,对于iOS项目的工程化要求也越来越高了,对于复杂的APP一般都需要对项目进行模块化管理。
模块化有几个方式:
1. 目录结构管理:这是最原始的方式,仅仅通过目录结构实现代码层次的清晰化。但本质上并没有解决代码之间的依赖混乱的情况,模块化划分也非常不清晰。
2. 子工程:通过子工程可以实现代码依赖管理和模块化,但是需要引入复杂的设置,不利于管理。
3. 静态库:将依赖代码打包成为静态库.a,不过由于不能看到源码,调试不方便。
自从有了CocoaPods,可以使用它来管理私有库,从而实现了代码模块化管理。例如下图所示:
CocoaPods私有库
1. 创建私有的Specs git库
例如在github上面创建一个空的git库:https://github.com/xxx/MySpecs
将这个git库加入到CocoaPods库的列表中:
$ pod repo add MySpecs git@github.com:xxx/MySpecs.git
此时可以检查下本地的pod repo
$ pod repo list MySpecs
- Type: git (master) - URL: git@github.com:xxx/MySpecs.git
- Path: /Users/xxx/.cocoapods/repos/mySpecs
master
- Type: git (master)
- URL: git@github.com:CocoaPods/Specs.git
- Path: /Users/xxx/.cocoapods/repos/master
确定私有库的Specs已经加到本地pod repo中。
2. 在私有库项目中创建podspec文件
在私有库项目中的根目录,创建对应的podspec文件,里面会描述这个库的基本信息。
PodSpec规范可以查看:https://guides.cocoapods.org/syntax/podspec.html
#
# Be sure to run `pod spec lint PodName.podspec' to ensure this is a
# valid spec and to remove all comments including this before submitting the spec.
# To learn more about Podspec attributes see http://docs.cocoapods.org/specification.html
# To see working Podspecs in the CocoaPods repo see https://github.com/CocoaPods/Specs/
#
Pod::Spec.new do |s|
s.name = "PodName"
s.version = "0.0.1"
s.summary = "A short description of PodName."
s.homepage = "http://github.com/xxx/PodName"
s.license = { :type => "MIT", :text => <<-LICENSE
Copyright © 2016年 xxx. All rights reserved.
LICENSE
}
s.author = { "" => "" }
s.source = { :git => "git@github.com:xxx/PodName.git", :tag => "0.0.1" }
s.source_files = "**/*.{h,m,mm,c}"
s.frameworks = "Foundation", "QuartzCore", "UIKit", "WebKit"
s.libraries = "z" s.dependency 'AFNetworking'
s.ios.deployment_target = '6.0'
end
resource: 可以指定资源文件,建议使用bundle以避免资源文件产生冲突。
frameworks: 指定这个pod依赖的系统framework
libraries: 指定这个pod依赖的系统动态库。注意使用的名字:比如需要引用"libz.dylib", 那么这里只需要写"z"
无论原始项目的目录结构或者group结构,默认的pod里面的代码都会平铺在根目录里面
如果需要增加目录层次结构,则需要使用subspec,详细使用规范:https://guides.cocoapods.org/syntax/podspec.html#subspec
注意:SubSpecs之间不能存在相互依赖关系,只能单向依赖
3. 验证私有库的合法性
$ pod lib lint --sources='git@github.com:xxx/MySpecs.git' --verbose --use-libraries --allow-warnings
sources参数可以指定私有库的Pod Specs库的地址。如果能够通过,说明代码编译没有问题。
4. 提交私有库的版本信息
$ git tag -m "first release" "0.0.1"
$ git push --tags #推送tag到远端仓库
5. 向Spec Repo提交podspec
$ pod repo push MySpecs PodName.podspec --sources='git@github.com:xxx/MySpecs.git' --use-libraries --allow-warnings
这样就完成了一个CocoaPods的私有库的提交了,别人就可以在Podfile里面使用这个私有库了。
大家如果还有关于CocoaPods的用法,可以一起交流。大家玩的开心~
有兴趣同学可以关注微信公众号奶爸码农,不定期分享投资理财、IT相关内容:
基于CocoaPods的iOS项目模块化实践的更多相关文章
- 基于maven的javaweb项目模块化开发
转自:https://my.oschina.net/kingfire/blog/273381 基于maven的javaweb项目模块化开发 引言 考虑团队拥有多个类似项目的情况,比如一些功能差异不大的 ...
- 基于springboot的web项目最佳实践
springboot 可以说是现在做javaweb开发最火的技术,我在基于springboot搭建项目的过程中,踩过不少坑,发现整合框架时并非仅仅引入starter 那么简单. 要做到简单,易用,扩展 ...
- 基于facebook-wda的iOS自动化操作实践记录
[本文出自天外归云的博客园] 原理 对于iOS自动化操作,主要靠WebDriverAgent来完成.在Mac电脑上连接真机iPhone,运行WebDriverAgentRunner会在Mac端启动WD ...
- CocoaPods管理iOS项目 2018年11月06日
一.创建Test工程项目 二.打开终端 当前pod版本(1.6.0.beta.2最新版本2018年11月06日)和gem源路径(https://gems.ruby-china.com): 1.cd+当 ...
- 对于CocoaPods的简单理解,实践安装使用过程和常见问题
(本文是自己通过其他文章进行的自我编辑和简单修改,请大家凑活看看) 一.什么是CocoaPods CocoaPods是iOS项目的依赖管理工具,该项目源码在Github上管理.开发iOS项目不可避免地 ...
- 创建ReactNative的iOS项目
http://reactnative.cn/docs/integration-with-existing-apps/ 1.安装好ReactNative开发环境 2.安装好CocoaPods 3.创建项 ...
- iOS项目开发实战——使用CoreLocation获取当前位置信息
随着基于位置服务LBS和移动互联网的兴起,你的位置是越来越重要的一个信息.位置服务已经是当前的热门应用如微信.陌陌等社交应用的杀手锏.而在iOS开发中,苹果已经给我们提供了一个位置接口.CoreLoc ...
- iOS业务模块化利用CocoaPod入门实践
iOS业务模块化即是通过不同的工程管理不同的业务,通常应用在中大型项目中,这样做的好处主要有:1.多人开发时,防止工程文件冲突 2.能够为下个不同的项目抽取代码,话不多说,直接看步骤:括号内容为本例 ...
- 前端项目模块化的实践3:使用 TypeScript 的收益
以下是关于前端项目模块化的实践,包含以下内容: 搭建 NPM 私有仓库管理源码及依赖: 使用 Webpack 打包基础设施代码: 使用 TypeScript 编写可靠类库 使用 TypeScript ...
随机推荐
- .net 定时服务
namespace MvcApplication1 { public class MvcApplication : System.Web.HttpApplication { protected voi ...
- Android应用程序开发以及背后的设计思想深度剖析
1 http://www.uml.org.cn/mobiledev/201211063.asp 2 ...
- OpenGL三角形的双面不同颜色的绘制
对于一个三角形,我要给它正反面不同的颜色.然后通过旋转,看出它的效果. 我只想到了2种方法,下面我来写一下这两种方法. 第一种方法,通过角度的判断重设glColor3f的参数(这种方法局限性很大,不推 ...
- redis 的安装与启动
1.redis介绍 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value数据库,并提供多种语言的API. Redis 是一个高性能的key-val ...
- linux下OpenSSL的RSA密钥生成
工具的安装: 一.源码安装 OpenSSL Version:openssl-1.0.0e.tar.gz ------------------------安装: 1.将下载的压缩包放在根目录, 2.在文 ...
- Spring Framework简单介绍
Spring Framework 学习java编程不知不觉已经三年时间了,開始的时候,总是喜欢看着视频,然后按部就班的敲打着键盘,每当系统正常执行后.心里乐开了花.最開始的时候,所有的代 ...
- iOS CAGradientLayer白色渐变至上向下
项目需求当显示富文本内容高度太高的的时候不全部显示出来,而是显示查看更多按钮,当点击查看更多时把全部内容展开.同时未展开部分要加一个渐变模糊的效果. 上效果图: 这里要用到CAGradientLaye ...
- php使用imagick模块实现图片缩放、裁剪、压缩示例
PHP 使用Imagick模块 缩放,裁剪,压缩图片 包括gif图片 缩放 裁剪 复制代码代码如下: /** * 图片裁剪 * 裁剪规则: * 1. 高度为空或为零 按宽度缩放 高度自适 ...
- 【SQLServer2008】之Telnet以及1433端口设置
Telnet步骤: 一.首先进入Win7控制面板,可以从开始里找到或者在桌面上找到计算机,点击进入里面也可以找到控制面板,如下图: 二.进入控制面板后,我们再找到“程序和功能”并点击进入,如下图所示: ...
- jmeter java 请求 payload
1.注册页面抓包看见内容如下: POST http://test.nnzhp.cn/bbs/forum.php?mod=post&action=edit&extra=&edit ...