原理
-
CocoaPods的原理,它是将所有的依赖库都放到另一个名为Pods项目中,然后 让主项目依赖Pods项目,这样,源码管理工作都从主项目移到了Pods项目中
1、Pods项目最终会编译成一个名为libPods.a的文件,主项目只需要依赖这个.a 文件即可。
2、对于资源文件,CocoaPods提供了一个名为Pods-resources.sh的bash脚本, 该脚本在每次项目编译的时候都会执行,将第三方库的各种资源文件复制到目 标目录中。
3、CocoaPods通过一个名为Pods.xcconfig的文件来在编译时设置所有的依赖和 参数。
-
注意
- 关于.gitignore
当你执行pod install之后,除了Podfile外,CocoaPods还会生成一个名为 Podfile.lock的文件,你不应该把这个文件加入到.gitignore中。因为Podfile.lock 会锁定当前各依赖库的版本,之后如果多次执行pod install 不会更改版本,要 pod update才会改Podfile.lock了。这样多人协作的时候,可以防止第三方库升 级时造成大家各自的第三方库版本不一致 。
常用指令
1.podinstall--no-repo-update(禁止索引更新操作)podupdate--no-repo-update
2.pod serach:'pod search AFNetworking'
3.pod outdated:'检查各第三方库是否有更新'
4.pod init:自动生成一个podfile文件并初始化
5.vim 编辑模式,输入i进入编辑,按ESC退出编辑,按:,输入wq回到控制台
可能遇到的问题
(1)使用cocoapods导入第三方类库后头文件没有代码提示?
解决办法: 选择Target -> Build Settings 菜单,找到\”User Header Search Paths\”设置项,新增一个值"${SRCROOT}",并且选择\”Recursive\”
(2)出现如下警告
[!] Your Podfile has had smart quotessanitised. To avoid issues in the future, you should not use TextEdit forediting it. If you are not using TextEdit, you should turn off smart quotes inyour editor of choice.
解决办法:不要使用文本编辑去编辑Podfile,使用Xcode编辑,或者使用终端敲命令去编辑。
(3) 执行pod install 或pod update 命令后,updating local specsrepositories 卡住不动
解决办法:pod install 被墙了,换成新的命令pod install --verbose --no-repo-update
(4) 项目运行时报错:Thefile “Pods.xcconfig” couldn’t be opened because there is no such file.
解决办法:pod update就可以了
1.先升级Gem sudo gemupdate--system
2.切换cocoapods的数据源 【先删除,再添加,查看】 gem sources--remove https://rubygems.org/gem sources -a https://ruby.taobao.org/ gem sources -l
3.安装cocoapods sudo geminstallcocoapods 或者(如10.11系统)sudo geminstall-n/usr/local/bincocoapods
4.将Podspec文件托管地址从github切换到国内的oschina 【先删除,再添加,再更新】 pod repo removemasterpod repoaddmasterhttps://gitcafe.com/akuandev/Specs.git pod repoupdate
5.设置pod仓库 pod setup
6.测试 【如果有版本号,则说明已经安装成功】 pod--version
7.利用cocoapods来安装第三方框架01进入要安装框架的项目的.xcodeproj同级文件夹02在该文件夹中新建一个文件podfile03在文件中告诉cocoapods需要安装的框架信息 a.该框架支持的平台 b.适用的iOS版本c.框架的名称d.框架的版本
8.安装podinstall--no-repo-updatepodupdate--no-repo-update
9.说明platform :ios,'8.0'用来设置所有第三方库所支持的iOS最低版本pod'SDWebImage','~>2.6'设置框架的名称和版本号格式参照最新版本,------------pod init中标准格式版本号的规则:'>1.0'可以安装任何高于1.0的版本'>=1.0'可以安装任何高于或等于1.0的版本'<1.0'任何低于1.0的版本'<=1.0'任何低于或等于1.0的版本'~>0.1'任何高于或等于0.1的版本,但是不包含高于1.0的版本'~>0'任何版本,相当于不指定版本,默认采用最新版本号
10.使用podinstall命令安装框架后的大致过程:01分析依赖:该步骤会分析Podfile,查看不同类库之间的依赖情况。如果有多个类库依赖于同一个类库,但是依赖于不同的版本,那么cocoaPods会自动设置一个兼容的版本。02下载依赖:根据分析依赖的结果,下载指定版本的类库到本地项目中。03生成Pods项目:创建一个Pods项目专门用来编译和管理第三方框架,CocoaPods会将所需的框架,库等内容添加到项目中,并且进行相应的配置。04整合Pods项目:将Pods和项目整合到一个工作空间中,并且设置文件链接。
11. 注意苹果系统升级OS X EL Capitan后改为$sudo geminstall-n/usr/local/bincocoapods, 要在指令前面加上sudo,会提醒输入密码,然后安装
Cocoapods指令
Usage:
$ pod COMMAND
CocoaPods, the Cocoa library package manager.
Commands:
+cacheManipulate the CocoaPodscache
+ deintegrate Deintegrate CocoaPodsfromyourproject.
+ env Display pod environment
+ init Generate a Podfileforthecurrentdirectory.
+installInstallprojectdependenciestoPodfile.lockversions+ ipc Inter-process communication
+ lib Develop pods
+listListpods
+ outdatedShowoutdatedprojectdependencies
+ pluginsShowavailable CocoaPods plugins
+ repo Manage spec-repositories
+searchSearchforpods.
+ setup Setup the CocoaPods environment
+ spec Manage pod specs
+ trunk Interactwiththe CocoaPods API (e.g. publishingnewspecs)
+ try Try a Pod!
+updateUpdateoutdatedprojectdependenciesandcreatenewPodfile.lock
Options:
--silent Show nothing
--version Show the version of the tool
--verbose Show more debugging information
--no-ansi Show output without ANSI codes
--help Show help banner of specified command