CocoaPods是什么?
當(dāng)你開發(fā)iOS應(yīng)用時遥倦,會經(jīng)常使用到很多第三方開源類庫谤绳,比如JSONKit,AFNetWorking等等谊迄∶乒可能某個類庫又用到其他類庫,所以要使用它统诺,必須得另外下載其他類庫歪脏,而其他類庫又用到其他類庫,“子子孫孫無窮盡也”粮呢,這也許是比較特殊的情況婿失〕В總之小編的意思就是,手動一個個去下載所需類庫十分麻煩豪硅。另外一種常見情況是哩照,你項目中用到的類庫有更新,你必須得重新下載新版本懒浮,重新加入到項目中飘弧,十分麻煩。如果能有什么工具能解決這些惱人的問題砚著,那將“善莫大焉”次伶。所以,你需要 CocoaPods稽穆。
CocoaPods應(yīng)該是iOS最常用最有名的類庫管理工具了冠王,上述兩個煩人的問題,通過cocoaPods舌镶,只需要一行命令就可以完全解決柱彻,當(dāng)然前提是你必須正確設(shè)置它。重要的是餐胀,絕大部分有名的開源類庫哟楷,都支持CocoaPods。所以骂澄,作為iOS程序員的我們吓蘑,掌握CocoaPods的使用是必不可少的基本技能了。
如何下載和安裝CocoaPods坟冲?
在安裝CocoaPods之前磨镶,首先要在本地安裝好Ruby環(huán)境。至于如何在Mac中安裝好Ruby環(huán)境健提,請google一下琳猫,本文不再涉及。
假如你在本地已經(jīng)安裝好Ruby環(huán)境私痹,那么下載和安裝CocoaPods將十分簡單脐嫂,只需要一行命令。在Terminator(也就是終端)中輸入以下命令(注意紊遵,本文所有命令都是在終端中輸入并運行的账千。什么,你不知道什么是終端暗膜?那請小編吃飯匀奏,小編告訴你):
sudo gem install cocoa pods
但是,且慢学搜。如果你在天朝娃善,在終端中敲入這個命令之后论衍,會發(fā)現(xiàn)半天沒有任何反應(yīng)。原因無他聚磺,因為那堵墻阻擋了cocoapods.org坯台。(你會問,我靠瘫寝,這都要墻蜒蕾!是的,小編也納悶矢沿。)
但是滥搭,是的,又但是(不過是個可喜的“但是”)捣鲸。我們可以用淘寶的Ruby鏡像來訪問cocoapods。按照下面的順序在終端中敲入依次敲入命令:
$ gem sources --remove https://rubygems.org/
//等有反應(yīng)之后再敲入以下命令(淘寶鏡像已換成https協(xié)議)
$ gem sources -a https://ruby.taobao.org/
為了驗證你的Ruby鏡像是并且僅是taobao闽坡,可以用以下命令查看:
$ gem sources -l
只有在終端中出現(xiàn)下面文字才表明你上面的命令是成功的:
*** CURRENT SOURCES ***
http://ruby.taobao.org/
這時候栽惶,你再次在終端中運行:
$ sudo gem install cocoapods
等上十幾秒鐘,CocoaPods就可以在你本地下載并且安裝好了疾嗅,不再需要其他設(shè)置外厂。
看到這里,你心里會不會說代承,我靠汁蝶!太爽了,這么容易就可以下載并且安裝好了论悴!是的掖棉,小編也是這么想的。CocoPods就是這么簡單膀估,使用也十分簡單幔亥。繼續(xù)往下看吧。
如何使用CocoaPods察纯?
好了帕棉,安裝好CocoPods之后,接下來就是使用它饼记。所幸香伴,使用CocoPods和安裝它一樣簡單,也是通過一兩行命令就可以搞定具则。
小編在這里用兩種使用場景來具體說明如何使用CocoaPods即纲。
場景1:利用CocoaPods,在項目中導(dǎo)入AFNetworking類庫
AFNetworking類庫在GitHub地址是:https://github.com/AFNetworking/AFNetworking
為了確定AFNetworking是否支持CocoaPods乡洼,可以用CocoaPods的搜索功能驗證一下崇裁。在終端中輸入:
$ pod search AFNetworking
你看到這里也許會問匕坯,CocoaPods為什么能下載AFNetworking呢,而不是下載其他類庫呢拔稳?這個問題的答案是葛峻,有個文件來控制CocoaPods該下載什么。這個文件就叫做“Podfile”(注意巴比,一定得是這個文件名术奖,而且沒有后綴)。你創(chuàng)建一個Podfile文件轻绞,然后在里面添加你需要下載的類庫采记,也就是告訴CocoaPods,“某某和某某和某某某政勃,快到碗里來唧龄!”。每個項目只需要一個Podfile文件奸远。
好吧既棺,廢話少說,我們先創(chuàng)建這個神奇的PodFile懒叛。在終端中進(jìn)入(cd命令)你項目所在目錄丸冕,然后在當(dāng)前目錄下,利用vim創(chuàng)建Podfile薛窥,運行:
$ vim podfile
然后在Podfile文件中輸入以下文字:
platform :ios, '7.0'
pod "AFNetworking", "~> 2.0"
注意胖烛,這段文字不是小編憑空生成的,可以在AFNetworking的github頁面找到诅迷。這兩句文字的意思是佩番,當(dāng)前AFNetworking支持的iOS最高版本是iOS 7.0, 要下載的AFNetworking版本是2.0。
然后保存退出竟贯。vim環(huán)境下答捕,保存退出命令是:
:wq
這時候,你會發(fā)現(xiàn)你的項目目錄中屑那,出現(xiàn)一個名字為Podfile的文件拱镐,而且文件內(nèi)容就是你剛剛輸入的內(nèi)容。注意持际,Podfile文件應(yīng)該和你的工程文件.xcodeproj在同一個目錄下沃琅。
這時候,你就可以利用CocoPods下載AFNetworking類庫了蜘欲。還是在終端中的當(dāng)前項目目錄下益眉,運行以下命令:
$ pod install
因為是在你的項目中導(dǎo)入AFNetworking,這就是為什么這個命令需要你進(jìn)入你的項目所在目錄中運行。
運行上述命令之后郭脂,小編的終端出現(xiàn)以下信息:
EricmatoMacBook-Pro:CocoaPodsDemo ericwang$ pod install
Analyzing dependencies
Downloading dependencies
Installing AFNetworking (2.0.2)
Generating Pods project
Integrating client project
[!] From now on use `CocoaPodsDemo.xcworkspace`.
注意最后一句話年碘,意思是:以后打開項目就用 CocoaPodsDemo.xcworkspace 打開,而不是之前的.xcodeproj文件展鸡。
現(xiàn)在屿衅,你就可以開始使用AFNetworking.h啦∮ū祝可以稍微測試一下涤久,在你的項目任意代碼文件中輸入:
#import <AFNetworking>
然后編譯,看看是否出錯忍弛。如果你嚴(yán)格按照小編上述的步驟來响迂,是不可能出錯的啦。
至此细疚,CocoPods的第一個應(yīng)用場景講述完畢蔗彤。別看小編寫了這么多,其實過程是十分簡單的惠昔∧挥耄總結(jié)一下就是:
先在項目中創(chuàng)建Podfile,Podfile的內(nèi)容是你想導(dǎo)入的類庫镇防。一般類庫的原作者會告訴你導(dǎo)入該類庫應(yīng)該如何寫Podfile;
運行命令:`$ pod install.
下面潮饱,小編繼續(xù)講述第二種使用場景来氧。
場景2:如何正確編譯運行一個包含CocoPods類庫的項目
你也許曾經(jīng)遇到過(特別是新手iOS開發(fā)者)這種情況,好不容易在GitHub上找到一份代碼符合自己想需求香拉,興沖沖下載下來啦扬,一編譯,傻眼了凫碌,發(fā)現(xiàn)有各種各樣錯誤扑毡。一看,原來是缺失了各種其他第三方類庫盛险。這時候莫慌瞄摊,你再仔細(xì)一看,會發(fā)現(xiàn)你下載的代碼包含了Podfile苦掘。沒錯换帜,這意味著你可以用CocoaPods很方便下載所需要的類庫。
下面鹤啡,小編以代碼 UAAppReviewManager 為例來說明如何正確編譯運行一個包含CocoPods類庫的項目惯驼。
UAAppReviewManager是一個能夠讓你方便地將提醒用戶評分的功能加入你的應(yīng)用中。當(dāng)你去UAAppReviewManager的GitHub地址下載這份代碼之后,打開Example工程(UAAppReviewManagerExample)祟牲,編譯隙畜,你會發(fā)現(xiàn)Xcode報告一大堆錯誤,基本都是說你編譯的這份代碼找不到某某頭文件说贝,這就意味著你要成功編譯UAAppReviewManager的Example代碼议惰,必須先導(dǎo)入一些第三方類庫。
這時候狂丝,打開終端换淆,進(jìn)入UAAppReviewManagerExample所在的目錄,也就是和Podfile在同一目錄下几颜,和場景1一樣倍试,輸入以下命令(由于已經(jīng)有Podfile,所以不需要再創(chuàng)建Podfile):
$ pod update
過幾秒(也許需要十幾秒蛋哭,取決于你的網(wǎng)絡(luò)狀況)之后县习,終端出現(xiàn):
Analyzing dependencies
Fetching podspec for `UAAppReviewManager` from `../`
Downloading dependencies
Installing UAAppReviewManager (0.1.6)
Generating Pods project
Integrating client project
[!] From now on use `UAAppReviewManagerExample.xcworkspace`.
這時候,再回到UAAppReviewManagerExample文件夾看一看谆趾,會看到多了一個文件UAAppReviewManagerExample.xcworkspace
根據(jù)終端的信息提示躁愿,你以后就需用新產(chǎn)生的UAAppReviewManagerExample.xcworkspace來運行這個Example代碼了。
打開UAAppReviewManagerExample.xcworkspace沪蓬,編譯運行彤钟,成功!
注意跷叉,這里有個小問題逸雹,如果剛剛你不是輸入$ pod update,而是輸入$ pod install云挟,會發(fā)現(xiàn)類庫導(dǎo)入不成功梆砸,并且終端出現(xiàn)下面提示:
[!] Required version (UAAppReviewManager (from `../`)) not found for `UAAppReviewManager`.
Available versions: 0.1.6
這里的意思大概是Podfile文件過期,類庫有升級园欣,但是Podfile沒有更改帖世。$ pod install只會按照Podfile的要求來請求類庫,如果類庫版本號有變化沸枯,那么將獲取失敗日矫。但是 $ pod update會更新所有的類庫,獲取最新版本的類庫辉饱。而且你會發(fā)現(xiàn)搬男,如果用了 $ pod update,再用 $ pod install 就成功了彭沼。
那你也許會問缔逛,什么時候用 $ pod install,什么時候用 $ pod update 呢,我又不知道類庫有沒有新版本褐奴。好吧按脚,那你每次直接用 $ pod update 算了《囟或者先用 $ pod install辅搬,如果不行,再用 $ pod update脖旱。
轉(zhuǎn)載:http://code4app.com/article/cocoapods-install-usage