當你開發iOS應用時,會常用到不少第三方開源類庫,好比JSONKit,AFNetWorking等等。可能某個類庫又用到其餘類庫,因此要使用它,必須得另外下載其餘類庫,而其餘類庫又用到其餘類庫,「子子孫孫無窮盡也」,這也許是比較特殊的狀況。總之小編的意思就是,手動一個個去下載所需類庫十分麻煩。另一種常見狀況是,你項目中用到的類庫有更新,你必須得從新下載新版本,從新加入到項目中,十分麻煩。若是能有什麼工具能解決這些惱人的問題,那將「善莫大焉」。因此,你須要 CocoaPods。ios
CocoaPods應該是iOS最經常使用最有名的類庫管理工具了,上述兩個煩人的問題,經過cocoaPods,只須要一行命令就能夠徹底解決,固然前提是你必須正確設置它。重要的是,絕大部分有名的開源類庫,都支持CocoaPods。因此,做爲iOS程序員的咱們,掌握CocoaPods的使用是必不可少的基本技能了。git
在安裝CocoaPods以前,首先要在本地安裝好Ruby環境。至於如何在Mac中安裝好Ruby環境,請google一下,本文再也不涉及。程序員
假如你在本地已經安裝好Ruby環境,那麼下載和安裝CocoaPods將十分簡單,只須要一行命令。在Terminator(也就是終端)中輸入如下命令(注意,本文全部命令都是在終端中輸入並運行的。什麼,你不知道什麼是終端?那請小編吃飯,小編告訴你):github
sudo gem install cocoapods
可是,且慢。若是你在天朝,在終端中敲入這個命令以後,會發現半天沒有任何反應。緣由無他,由於那堵牆阻擋了cocoapods.org。(你會問,我靠,這都要牆!是的,小編也納悶。)vim
可是,是的,又可是(不過是個可喜的「可是」)。咱們能夠用淘寶的Ruby鏡像來訪問cocoapods。按照下面的順序在終端中敲入依次敲入命令:xcode
$ gem sources --remove https://rubygems.org/ //等有反應以後再敲入如下命令 $ gem sources -a http://ruby.taobao.org/
爲了驗證你的Ruby鏡像是而且僅是taobao,能夠用如下命令查看:ruby
$ gem sources -l
只有在終端中出現下面文字才代表你上面的命令是成功的:bash
*** CURRENT SOURCES *** http://ruby.taobao.org/
再次在終端中運行:工具
$ sudo gem install cocoapods
等上十幾秒鐘,CocoaPods就能夠在你本地下載而且安裝好了,再也不須要其餘設置。測試
敲入以上命令時,小編終端上是這個樣子的(因爲太長,僅截取前面一部分):
看到這裏,你內心會不會說,我靠!太爽了,這麼容易就能夠下載而且安裝好了!是的,小編也是這麼想的。CocoPods就是這麼簡單,使用也十分簡單。繼續往下看吧。
好了,安裝好CocoPods以後,接下來就是使用它。所幸,使用CocoPods和安裝它同樣簡單,也是經過一兩行命令就能夠搞定。
小編在這裏用兩種使用場景來具體說明如何使用CocoaPods。
AFNetworking類庫在GitHub地址是:https://github.com/AFNetworking/AFNetworking
爲了肯定AFNetworking是否支持CocoaPods,能夠用CocoaPods的搜索功能驗證一下。在終端中輸入:
$ pod search AFNetworking
過幾秒鐘以後,你會在終端中看到關於AFNetworking類庫的一些信息。
這說明,AFNetworking是支持CocoaPods,因此咱們能夠利用CocoaPods將AFNetworking導入你的項目中。
首先,咱們須要在咱們的項目中加入CocoaPods的支持。你能夠跟隨小編的步驟,先利用Xcode建立一個名字CocoaPodsDemo的項目,用於如下的教程。建立好以後,在繼續下一步以前,小編先截圖,看看項目沒有支持CocoaPods時的項目Xcode目錄結構:
你看到這裏也許會問,CocoaPods爲何能下載AFNetworking呢,而不是下載其餘類庫呢?這個問題的答案是,有個文件來控制CocoaPods該下載什麼。這個文件就叫作「Podfile」(注意,必定得是這個文件名,並且沒有後綴)。你建立一個Podfile文件,而後在裏面添加你須要下載的類庫,也就是告訴CocoaPods,「某某和某某和某某某,快到碗裏來!」。每一個項目只須要一個Podfile文件。
好吧,廢話少說,咱們先建立這個神奇的PodFile。在終端中進入(cd命令)你項目所在目錄,而後在當前目錄下,利用vim建立Podfile,運行:
$ vim Podfile
而後在Podfile文件中輸入如下文字:
platform :ios, '7.0' pod "AFNetworking", "~> 2.0"
注意,這段文字不是小編憑空生成的,能夠在AFNetworking的github頁面找到。這兩句文字的意思是,當前AFNetworking支持的iOS最高版本是iOS 7.0, 要下載的AFNetworking版本是2.0。
而後保存退出。vim環境下,保存退出命令是:
:wq
這時候,你會發現你的項目目錄中,出現一個名字爲Podfile的文件,並且文件內容就是你剛剛輸入的內容。注意,Podfile文件應該和你的工程文件.xcodeproj在同一個目錄下。
這時候,你就能夠利用CocoPods下載AFNetworking類庫了。仍是在終端中的當前項目目錄下,運行如下命令:
$ pod install
由於是在你的項目中導入AFNetworking,這就是爲何這個命令須要你進入你的項目所在目錄中運行。
運行上述命令以後,小編的終端出現如下信息:
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文件。
你也許會鬱悶,爲何會出現.xcodeproj文件呢。這正是你剛剛運行$ pod install
命令產生的新文件。除了這個文件,你會發現還多了另一個文件「Podfile.lock」和一個文件夾「Pods」。 點擊 CocoaPodsDemo.xcworkspace 打開以後工程以後,項目Xcode目錄結構以下圖:
你會驚喜地發現,AFNetwoking已經成功導入項目了(紅框部分)!
如今,你就能夠開始使用AFNetworking.h啦。能夠稍微測試一下,在你的項目任意代碼文件中輸入:
#import <AFNetworking.h> 或者 #import "AFNetworking.h"
而後編譯,看看是否出錯。若是你嚴格按照小編上述的步驟來,是不可能出錯的啦。
至此,CocoPods的第一個應用場景講述完畢。別看小編寫了這麼多,其實過程是十分簡單的。總結一下就是:
`$ pod install
.