[toc]
前言
創(chuàng)建一個項目在xcode
中有以下三項,在平時開發(fā)不是很大型的項目,很少會注意這些問題。
Xcode配置
-
Project
:包含了項?所有的代碼,資源?件,所有信息 -
Target
:對某些代碼和資源文件的構(gòu)建方式 -
Scheme
:對指定的Targe
的配置
真正打工干事就是target。
多環(huán)境管理 一套代碼多app管理
開發(fā)環(huán)境 預(yù)發(fā)布環(huán)境 正式環(huán)境使用的地址都是不同的每次打包都需手動切換是很麻煩的一件事,有么有一鍵配置好所有的內(nèi)容,打包切換一下target呢?
肯定有解決方案
方案一 Duplicate
- 選擇Duplicate,發(fā)現(xiàn)項目中多一個
list
文件高級技巧01 copy-Info.plist
- 配置宏
3.項目中使用,定義一個宏,將工程切換到高級技巧01 copy
,打印
這種修改適用于代碼改動不大,只是改了一寫接口,第三方申請key等都可以在一個地址集中修改,但是這樣還是不夠方便
方案二 configurations
- 配置
Configuration
的目的是為了增加或刪除編譯環(huán)境
對于不同編譯環(huán)境下的參數(shù)需求可以到xcconfig
中進(jìn)行設(shè)置。 - 以下例子未使用xconfig。
- 增加一個配置Debug_pre
- 在這里修改bundle ID根據(jù)項目開發(fā)需要
- 設(shè)置對應(yīng)的域名
- info.plist文件設(shè)置key去build seting里面對應(yīng)key所對應(yīng)的值
- 創(chuàng)建scheme打到多環(huán)境,每個scheme對應(yīng)一個環(huán)境
- 在
APPdelegate
配置獲取HOSt_URL
的路徑,切換scheme
查看打印結(jié)果
- debug
- debug_pre
- release
上面方式基本可以滿意開發(fā)需求,但是針對于pod項目還是需求另一種解決方案。
方案三 Configuration+xcconfig
- 配置xcconfig
xcconfig
文件的修改實際上是修改build setting
中的參數(shù)。相關(guān)縮寫看Xcode.Build Setting 里的關(guān)鍵字含義。
- 現(xiàn)在配置debug和releas環(huán)境
命名規(guī)范目錄+app名稱+環(huán)境+xcconfig后綴
1.選擇文件
2.命名,配置
3.如果使用pod,在執(zhí)行pod install會報以下錯誤
[百度的解釋,具體博客作者忘記了] 大概意思是你需要你配置的
xcconfig文件
中導(dǎo)入pod配置
文件的路徑。在完成一次pod install
之后,Pods
工程會為每一個環(huán)境生成一個xcconfig
文件,包括默認(rèn)的debug
環(huán)境,如果我們的目標(biāo)工程對應(yīng)的環(huán)境沒有配置xcconfig
文件,那么就會在當(dāng)前工程工程下拷貝一份對應(yīng)的xcconfig
文件并自動在環(huán)境中完成配置,這種配置讓工程能夠使用pod
。
我們只需要在其他xcconfig
文件中導(dǎo)入相關(guān)的pod
下的xcconfig
就好了,記得使用相對路徑,否則在其他電腦上就不能運行了:
- XXXXXX文件名稱
#include "Pods/Target Support Files/XXXXXX.xcconfig"
key也可以知道環(huán)境模擬器架構(gòu)
OTHER_LDFLAGS[config=Debug][sdk=iphonesimulator*][arch=x86_64]=-framework "AFN"
xconfig編寫指南
xcconfig
文件的語法比較簡單,每個配置文件都由一系列鍵值分配組成,這些鍵值分配具有以下語法:
BUILD_SETTING_NAME = value
注釋
xcconfig文件只有一種注釋方式\。
include導(dǎo)入其他設(shè)置
- 在創(chuàng)建
xcconfig
文件的時候,可以根據(jù)需求,創(chuàng)建多個。也就意味著,可以通過include
關(guān)鍵字導(dǎo)入其他的xcconfig
內(nèi)的配置。通過include
關(guān)鍵字后接上雙引號:
#include "Debug.xcconfig"
- 在搜索引入的文件時,如果是以/開頭,代表絕對路徑,例如:
// 表示確切的文件位置
#include "/Volumes/zed/iOS\ dsb/iOS\ 高級技巧\ 練習(xí)/高級技巧01/Pods/Target\ Support\ Files/Pods-高級技巧01/Pods-高級技巧01.debug.xcconfig"
- 或者通過相對路徑,以${SRCROOT}路徑為開始:
#include "Pods/Target Support Files/Pods-LoginApp/Pods-LoginApp.debug.xcconfig"
變量
變量定義,按照OC
命名規(guī)則,僅由大寫字母,數(shù)字和下劃線(_)組,原則上大寫,也可以不。字符串可以是"也可以是'號。
變量有三種特殊情況:
- 在
xcconfig
中定義的變量與Build Settings
的一致,那么會發(fā)生覆蓋。可以通過$(inherited)
,讓當(dāng)前變量繼承變量原有值。例如:
OTHER_LDFLAGS = -framework SDWebImage
OTHER_LDFLAGS = $(inherited) -framework AFNetworking
// OTHER_LDFLAGS = -framework SDWebImage -framework AFNetworking
注意??:有部分變量不能通過xcconfig
配置到Build Settings
中,例如:配置PRODUCT_BUNDLE_IDENTIFIER
不起作用。
- 引用變量,
$()
和${}
兩種寫法都可以:
VALUE=Cat
TEACHER=$(VALUE)-${VALUE}
- 條件變量,根據(jù)
SDK、Arch
和Configration
對設(shè)置進(jìn)行條件化,例如:
// 指定`Configration`是`Debug`
// 指定`SDK`是模擬器,還有iphoneos*、macosx*等
// 指定生效架構(gòu)為`x86_64`
OTHER_LDFLAGS[config=Debug][sdk=iphonesimulator*[arch=x86_64]= $(inherited) -framework "test"
注意??:在Xcode 11.4及以后版本,可以使用default,來指定變量為空時的默認(rèn)值:
$(BUILD_SETTING_NAME:default=value)
優(yōu)先級(由高到低)
- 手動配置
Target Build Settings
-
Target
中配置的xcconfig
文件 - 手動配置
Project Build Settings
-
Project
中配置的xcconfig
文件