CocoaPods安装&使用

2016-05-31  本文已影响110人  Barry_小闪

CocoaPods简介

CocoaPods是一个用来帮助我们管理第三方依赖库的工具。它可以解决库与库之间的依赖关系,下载库的源代码,同时通过创建一个Xcode的workspace来将这些第三方库和我们的工程连接起来,供我们开发使用。

使用CocoaPods的目的是让我们能自动化的、集中的、直观的管理第三方开源库。

安装Ruby环境

检查Mac是否安装Ruby和gem

在终端中输入命令:ruby --versiongem --version

输出如下类似提示符,则表示Ruby环境已安装

$ ruby --version
ruby 2.0.0p643 (2015-02-25 revision 49749) [x86_64-darwin14.3.0]
$ gem --version
2.4.8

PS:Ruby是一门开发语言,gem为Ruby第三方库管理工具,CocoaPods是用Ruby写的一个第三方工具。

若提示command not found 则需要安装Ruby环境

安装CocoaPods

使用淘宝的镜像安装Ruby的第三方库,修改gem的镜像:

$ gem sources --remove https://rubygems.org/
$ gem sources -a https://ruby.taobao.org/

为了验证你的Ruby镜像是并且仅是淘宝,可以用以下命令查看:

$ gem sources -l
# 只有在终端中出现下面文字才表明你上面的命令是成功的:
* CURRENT SOURCES *
https://ruby.taobao.org/

如果出现多个需要将其余的源删除。

终端中执行安装CocoaPods

$ sudo gem install cocoapods

执行完成后,需要初始化CocoaPods的环境

$ pod setup

CocoaPods查看安装进度

打开一个新的终端
$ cd ~/.cocoapods
$ du -sh *
 56K    repos

使用CocoaPods

  1. 创建Xcode工程并切换到该工程路径

  2. 使用命令pod init在当前文件夹下生成一个Podfile文件

  3. 编辑该文件,在该文件中输入如下信息:

platform :ios, '8.0'
target 'WeiboClientDemo' do

pod 'AFNetworking', '2.5.4'
pod 'KVNProgress'

end


该文件中的命令格式为:`pod '第三库名称', '版本号'`

第三库名称,名称一定要正确,不然有可能安装失败。

版本号标识区别

> \>= 1.0 至少版本为1.0
>
> ~> 1.0 兼容1.0版本的最新版
>
> == 1.0或1.0 都表示指定版本
4. 安装工程依赖的第三方库

``` shel
//输入 pod install 安装第三方库
$ pod install

Updating local specs repositories
Analyzing dependencies
Downloading dependencies
Installing AFNetworking (2.5.4)
Installing KVNProgress (2.2.2)
Installing SDWebImage (3.7.3)
Generating Pods project
Integrating client project
[!] Please close any current Xcode sessions and use `CocoaPodsDemo.xcworkspace` for this project from now on.
Sending stats
Pod installation complete! There are 3 dependencies from the Podfile and 3 total

//安装成功
pods installed.

若出现pods installed字样表示安装成功。

  1. 关闭Xcode工程,打开.xcworkspace文件。

  2. 在工程中导入第三库文件,只需要#import <AFNetworking.h>类似的即可,开启CocoaPods之旅。

更多用法参考本文提供的参考链接。

参考链接

  1. http://code4app.com/article/cocoapods-install-usage
  2. http://blog.csdn.net/wzzvictory/article/details/18737437
  3. http://blog.csdn.net/wzzvictory/article/details/19178709

Carthage

Carthage简介

Carthage的目标是用最简单的方式来管理Cocoa第三方框架。

Carthage编译你的依赖,并提供框架的二进制文件,但你仍然保留对项目的结构和设置的完整控制。Carthage不会自动的修改你的项目文件或编译设置。

Carthage只正式支持动态框架,动态框架能够在任何版本的OS X上使用,但只能在iOS 8及以上版本使用。

安装Homebrew

OS X 不可或缺的套件管理器,用于安装命令工具。

终端中执行如下命令:

/usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

安装Carthage

终端执行命令安装Carthage

brew update
brew install carthage

使用Carthage

  1. 创建Xcode工程并切换到该工程路径

  2. 创建一个Cartfile,将你想要使用的框架列在里面

    github "AFNetworking/AFNetworking" ~> 3.0
    github "rs/SDWebImage"
    
  3. 运行carthage update,将获取依赖文件到一个Carthage.checkout文件夹,然后编译每个依赖

  4. 在你的应用程序target的General设置标签中的Embedded Binaries区域,将框架从Carthage.build文件夹拖拽进去。

参考链接

  1. http://www.cocoachina.com/ios/20141204/10528.html
  2. 官方文档

Carthage与CocoaPods的不同

  1. Carthage只支持iOS 8及以上版本使用。

  2. 首先,CocoaPods默认会自动创建并更新你的应用程序和所有依赖的Xcode workspace。Carthage使用xcodebuild来编译框架的二进制文件,但如何集成它们将交由用户自己判断。CocoaPods的方法更易于使用,但Carthage更灵活并且是非侵入性的。

  3. CocoaPods的目标在它的README文件描述如下:

    …为提高第三方开源库的可见性和参与度,创建一个更中心化的生态系统。

    与之对照,Carthage创建的是去中心化的依赖管理器。它没有总项目的列表,这能够减少维护工作并且避免任何中心化带来的问题(如中央服务器宕机)。不过,这样也有一些缺点,就是项目的发现将更困难,用户将依赖于Github的趋势页面或者类似的代码库来寻找项目。

  4. CocoaPods项目同时还必须包含一个podspec文件,里面是项目的一些元数据,以及确定项目的编译方式。Carthage使用xcodebuild来编译依赖,而不是将他们集成进一个workspace,因此无需类似的设定文件。不过依赖需要包含自己的Xcode工程文件来描述如何编译。

  5. 最后,我们创建Carthage的原因是想要一种尽可能简单的工具——一个只关心本职工作的依赖管理器,而不是取代部分Xcode的功能,或者需要让框架作者做一些额外的工作。CocoaPods提供的一些特性很棒,但由于附加的复杂性,它们将不会被包含在Carthage当中。

上一篇下一篇

猜你喜欢

热点阅读