对于一个项目从生产力的角度来说,我们都不能保证自己写的每一行代码是否在某种程度上重复的造"轮子".换言之对于通用的功能,如果有更好"轮子"可以用来替代和供我们选择,那么管理好第三方包在项目中引用远比要重复造"轮子"要重要的多.
每种语言发展到一定阶段都会产生一定依赖管理工具,例如C#中Nuget[读作:New-Get],java中常用的Maven等.而对于iOS平台来说则不得不提到CocoaPods.该项目从2011年8月12日开始至今,经过数年的发展,虽然现在依然很多第三方依赖管理工具可以选择,事实上CocoaPods俨然已经成为iOS依赖管理的标准工具.从Github上针对iOS分类下富有影响力排名的项目对CocoaPods支持力度可见一斑.well,既然对于这个貌似没的选的工具,学会如何使用它就好.
安装CocoaPods
CocoaPods是基于Ruby环境运行的,当然Mac自身环境是自带Ruby和Rvm的.至于如何安装Ruby请自行Google,这里不再赘述.首先打开终端检查Rvm和Ruby版本:
二者都是latest版本.首先通过如下命令安装:
如果你发现突然很久没有反应,问题原因也很简单,哪怕这是一个全球流行依赖管理工具依然避免被墙的命运,所以解决方案有二,自备VPN挂上,或者通过淘宝的Ruby镜像来访问CocoaPods,这个就需要你对gem包来源[https://rubygems.org]更换成淘宝的,操作如下:
更换完成后查看是否更换成功:
更换成功.重新安装执行CocoaPods安装命名,过几十秒顺利安装成功.
引用第三方框架
构建项目时难免会用到很多第三方的库或者框架,类似对iOS常见的AFNetworking网络层封装库等,大多情况是我们一个项目可能会使用多个[多则达20也是常见的],对于多个第三方库依赖管理和自身库版本更新维护就会很大的工作量,所以至于手工拷贝源码到工程的方式,虽然操作简单却极容易出错,其实完全可以采用CocoaPods工具把这块功能管理做成自动化,尽量减少手工操作.
类似现在要在空的工程[CocoapodsDemo]中引入自动布局框架Masonry,一般在引入之前我们需要验证一下当前是否支持CocoaPods:
采用pod Search命令很快就能检索到对应框架版本结果.这说明Masonry是支持CocoaPods.而对于空白的工程来说,首先要加入对CocoaPods的支持,第一步需要创建一个Podfile文件(文件名不能变更,且无任何后缀).其实这个文件功能跟Visual Studio 中依赖包管理工具-Nuget中自带Xml格式包描述文件是一样的功能,它一般用来描述当前工程使用那些类库,支持系统版本,以及目前项目引用类库版本等信息.
首先打开终端进入项目根目录[.xcodeproj文件所在文件目录],通过Vim命名创建Podfile文件:
在Podfile文件输入如下信息:
pod 'Masonry'
注意这里输入信息,一般情况来自项目类库安装说明文档,类似Masonry在Github主页中关于采用CocoaPods安装方法就是如上一段字符.有的类库附带有系统版本和平台支持说明. 类库名字后面也可能会指定固定版本号.具体情况根据类库自身说明和项目需要的类库版本自行决定.
输入完成,按下"ESC"键,退回到命令行模式,在Vim采用:
:wq
命名强制保存退出.这时候你会发现项目根目录中,会出现一个名字为Podfile的文件,而且文件内容就是刚刚输入的. 这里值得注意的是,一般情况Podfile文件应该和工程文件.xcodeproj在同一个目录下.
建立Podfile文件成功后,这个时候执行pod install就开始安装Masonry框架到项目中来了:
其实执行pod install命名时,CocoaPods会读取Podfile找到相关类库下载并自动集成到项目中来.当开始执行安装时你大多情况都会发现安装流程会一直停留在:
Analyzing dependencies
这一项好久没有动,这个问题原因是因为首次使用pod install命名时,系统也会默认执行pod setup.命令执行时会升级CocoaPods的spec仓库.关于Pod Setup具体坐了那些事情详见这里.卡在这里不动原因也是毋庸置疑的,Setup流程引用资源被墙掉了.针对这个情况除了挂上靠谱VPN,在墙内还有两种比较靠谱方式可以解决:
自行下载Setup文件:
因为CocoaPods托管在github上,可以自行下载Setup所需要的文件,只要将文件夹名改为master,并将其拖到/Users/用户名/.cocoapods/repos目录下即可.
命令行忽略:
其实在pod install执行命令时可以设置相应参数,规避每次执行Setup更新spec仓库的操作:
pod install --verbose --no-repo-update
只要能够保证正常联通github基本上稍等一段时间就能顺利安装成功.安装成功后留意最后有一句提示的话:
[!] From now on use `CocoaPodsDemo.xcworkspace`.
意思是:因为引入新的Masonry框架,以后打开项目就用 CocoaPodsDemo.xcworkspace 打开,而不是之前的.xcodeproj文件.
重新打开空白的CocoaPodsDemo工程看一下项目结构与以前做一下对比:
你会发现Masonry自动布局框架已经自动安装到项目工程中来.
同理如果我们在第三方平台类似github看到比较好框架,或者要更新已有项目框架版本,只需要找到对应的Podfile执行对应update操作就能很好管理项目中使用到第三方库.
Pretty Easy.