在GitHub上,有着许多优秀的开源库,在项目开发中要去使用这些开源库呢?这里我们使用Cocoapods来帮我们集成、管理这些库~
一.Cocoapods的安装
1.升级Ruby
在终端中输入:
sudo gem update --system
输入系统密码后按回车,等待Ruby升级,当终端中显示RubyGems system software updated时,表示Ruby已经升级成功!
2.更换Ruby镜像
因为XX防火墙原因我们需要替换Ruby的镜像地址
首先查询当前的Ruby镜像地址
gem sources -l
记录地址后,将此地址移除
gem sources --remove 记录的地址
然后再添加最新的镜像
gem sources -a https://gems.ruby-china.com/
执行完成后也可再次查询当前Ruby镜像地址以确认是否修改成功
3.安装Cocoapods
sudo gem install cocoapods
如果出现如下报错信息:
是由于没有权限造成的,修改安装指令再次安装
sudo gem install -n /usr/local/bin cocoapods
显示如下信息时表示安装成功
下一步要执行pod setup将pod库的索引全部拉下来,这个操作比较耗时间,偶尔出现网络中断的情况,还得重新来一遍T_T
pod setup
当终端中显示Setting up CocoaPods master repo时,接下来就是漫长的等待。。。。。各位可以去喝个茶、看个番、搓个澡,当显示Setup completed
时,你就可以回来继续开始下面的内容了
如果您实在耐不住寂寞,又或是担心下载是不是中断了,有个小技巧可以安抚下强迫症:
新建一个终端窗口,执行cd ~/.cocoapods
进入该文件夹,再执行du -sh *
来查看文件夹大小,每个一段时间执行一下,看文件大小是否有变化就知道下载是不是在正常进行了( • ̀ω•́ )✧
二.Cocoapods的使用
1.搜索第三方库
以snapKit库为例,在终端中执行:
pod search 'snapkit'
稍等一会会出现搜索结果:
出现这个就说明搜索成功了~按Q退出搜索结果页
有时候也可能会出现搜索不到结果的情况,这里可能有两种情况:
- 1.因为以前搜索是生成了缓存文件
search_index.json
,我们可以将这个文件删除后,再进行搜索
终端中执行:
rm ~/Library/Caches/CocoaPods/search_index.json
- 2.有可能是我们本地的第三方库列表不是最新的原因,这时我们可以试着更新一下索引库,更新完毕后,可以再次尝试是否能搜索到
pod repo update
2.在工程中创建Podfile文件
首先,我们在终端中进入工程目录下:
cd /Users/xxx/Desktop/xcode/IOS演示项目/IOSDemo/
使用vim直接创建并编辑Podfile文件:
vim Podfile
进入后是这样的界面:
按i键开始编辑Podfile文件(注意关闭输入法)
内容如下:
platform :ios, '8.2'
use_frameworks!
target 'IOSDemo' do
pod 'snapKit','~> 0.1.17'
end
简单说一下代码的含义:
platform :ios, '8.2'
表示第三方库最低支持的IOS版本,一般在第三方库的GitHub主页的集成说明中都会标明
use_frameworks!
必填,在swift项目中用于生成framework
target 'IOSDemo' do
IOSDemo为当前工程的名称
pod 'SnapKit','~> 4.0.0'
需要引入的第三方库,可以换行填多个库的引用,SnapKit
为第三方库名称,4.0.0
为需要引入的版本号,前面的~>
符号表示引入此版本后最新的版本,不加这个符号的话,引入的就是制定的版本号,也可以只写pod 'SnapKit'
,这样引入的将是最新的版本
编辑完成后,我们先按esc
键退出编辑模式,再输入wq
,这样就完成了Podfile文件的编辑并退出
3.下载Podfile中集成的第三方库
在终端中输入:
pod install
等待一段安装时间,当显示如下内容时就表示下载完成了:
有时可能会出现下面这种更新失败的情况,提示找不到对应版本的库,但GitHub主页上却显示有最新版本,这可能之前说的本地的索引库没有更新的缘故,按照终端里的提示,执行
pod repo update
进行更新后再安装就行了~安装完成后,在工程目录下会出现一个和工程同名的
.xcworkspace
文件,以后我们打开工程就不是用.xcodeproj
而是使用.xcworkspace
文件打开了工程打开后,可以看到工程目录在多了一个Pods的项目,以后需要修改Podfile文件时,可以直接在这里编辑后再安装了(/≧▽≦)/
三.桥接文件
在swift工程中,有时我们引用的第三方库是用Objective-C开发的,这种库我们在swift开发中无法直接调用,这时就需要通过桥接的方式来引用了~
首先,在工程中新建桥接文件Header File
在
Build Settings
中设置桥接文件路径:在桥接文件中引用第三方库的头文件:
最后在Build一下工程,就大功告成啦ヽ(゚∀゚)メ(゚∀゚)ノ
至此,就可以在项目中愉快的引用第三方库了~