Xcode多環(huán)境配置

主要內(nèi)容:

  1. 區(qū)分Project、TargetScheme
  2. Target 配置
  3. Scheme配置
  4. xcconfig文件配置

一、區(qū)分Project、Target、Scheme

  • Project:是一個(gè)項(xiàng)目的整體,相當(dāng)于一個(gè)倉(cāng)庫(kù),包括了所有的代碼和資源文件;
  • Target:相當(dāng)于一個(gè)具體的產(chǎn)品,包含了對(duì)于代碼,資源文件的具體使用規(guī)則和配置;
  • Scheme: 對(duì)指定Target的環(huán)境進(jìn)行配置;

總結(jié):一個(gè)Project可以包含多個(gè)Target,也就是說通過不同Target我們可以生成不同的APP;

多環(huán)境配置的三種方法:

  1. target配置;
  2. Scheme配置;
  3. xcconfig文件配置;

二、多Target 配置

1.總結(jié)特點(diǎn)
  • 優(yōu)點(diǎn):方便管理代碼,資源文件,比如在Compile Sources、Copy Bundle Resources里根據(jù)需要增加或者刪除需要編譯的代碼和資源;
  • 缺點(diǎn):配置繁瑣,涉及多個(gè)info.plist文件、宏定義等,大量的修改人容易錯(cuò)亂;
2.基本步驟

1.創(chuàng)建新target

選中已有target,右鍵選擇Duplicate,會(huì)拷貝創(chuàng)建出與原Target相同配置的新Target

image

2.修改新target的配置

由于拷貝得到的target仍使用舊的配置,為了使用新target,所以我們還需要一些額外設(shè)置:

  1. 修改新Target名字;
  2. 修改新info.plist名字;
  3. 修改Build Settings -> Packaging -> info.plist FileProduct Bundle identifier;
image

3.修改Scheme名字

進(jìn)入Scheme Manager,修改Scheme的名字,這里并非必須,修改是為了更加方便識(shí)別;

image

4.為了區(qū)別不同的Target,增加預(yù)定義宏

配置OC工程:Build Settings -> Preprocessor Macros

image

配置Swift工程:Build Settings -> Other Swift Flags

image

理解-D用法:

  1. swiftc編譯器中,需要添加一個(gè)-Doption,代表將條件編譯標(biāo)志標(biāo)記為true;
  2. 至于-D的說明,也可以使用控制臺(tái)命令查看:swiftc --help |grep '-D'
-D <value>  Marks a conditional compilation flag as true

5.測(cè)試target多環(huán)境

#if DEV
   print("Project DEV")
#else
   print("Project Normal")
#endif

三、Scheme配置

配置Scheme實(shí)現(xiàn)多環(huán)境,其實(shí)是通過設(shè)置多種configurations的方式,具體步驟如下:

1.增加新configration

進(jìn)入Project -> Info -> Configurations,在這里可以看到已經(jīng)存在的Debug、Release等配置。點(diǎn)擊“+”,可以在這里增加新的configuration(以Dev為例);

image
2.切換多環(huán)境

增加configuration后,在Edit Scheme時(shí),也會(huì)多出一種configration。我們?cè)?code>run的時(shí)候,就可以手動(dòng)切換configration使用不同的環(huán)境;

image

3.多Scheme

每次手動(dòng)切換configration較為繁瑣,我們還可以使用不同的Scheme直接對(duì)應(yīng)不同的配置;

image

4.測(cè)試Scheme多環(huán)境

1.Build Setting -> User-Defined里自定義Host_URL,再對(duì)不同的configration配置不同的值;

image

2.將Host_URL以變量的方式配置到info.plist文件中;

image

3.讀取info.plist,手動(dòng)切換configration或者使用不同的Scheme運(yùn)行,將得到不同的信息;

guard let path = Bundle.main.path(forResource: "Info", ofType: "plist") else { return}
guard let infoDic = NSDictionary(contentsOfFile: path) else {return}
if let host_url = infoDic["HOST_URL"] {
   print("HOST_URL:\(host_url)")
}

四、xcconfig配置文件

xcconfig配置文件:

  1. .xcconfig配置文件,可以幫助我們以文件的形式配置build settings里的內(nèi)容;
  2. .xcconfig的文件的內(nèi)容,是以key-value形式構(gòu)成的;
  3. 增加.xcconfig文件后,依然可以繼續(xù)在build settings里增加配置項(xiàng)目,并不會(huì)覆蓋;
1.查看配置文件

其實(shí),若使用Cocoapods管理第三方庫(kù),就已經(jīng)自動(dòng)生成了DebugRelease配置文件。

查看配置:Xcode -> PROJECT -> info -> Configurations

image
2.自定義配置文件
  1. Commd +N -> 搜索Configuration Setting File,保存名稱以"目錄名-App名.環(huán)境"為格式, 如"Config-TestProject.debug";
  2. .xcconfig文件里寫入配置,而這里用到的key其實(shí)都是build settings配置選項(xiàng)的縮寫,具體可查看網(wǎng)站Xcode Build Settings;

舉例:在配置文件中寫入以下配置:

SLASH = /
HOST_URL = http:${SLASH}/1234
OTHER_LDFLAGS =  -framework "AFNetworking"
HEADER_SEARCH_PATHS = /abcd/efg

此時(shí)執(zhí)行編譯后,在build settings里搜索查看Other Linker FlagsHeader Search Paths,這些配置都已經(jīng)被成功修改;

3.特殊符號(hào)問題

在寫入配置信息時(shí),其中url//會(huì)被認(rèn)為是注釋。此時(shí),我們可以先定義一個(gè)變量SLASH = /, 如下代碼:

SLASH = /
HOST_URL = http:${SLASH}/5678
4.增加約束條件

某些情況下,我們需要為配置增加約束條件,如只在Debug環(huán)境下、SDK是模擬器,且架構(gòu)是x86_64的情況下才會(huì)link這個(gè)frameworkName,則需要如下配置:

OTHER_LDFLAGS[config=Debug][sdk=iphonesimulator*][arch=x86_64] = -framework "frameworkName"
5.xcconfig文件沖突問題

我們習(xí)慣于使用cocoapods管理第三方,由其生成的配置文件和我們自定義的配置文件就會(huì)沖突,因?yàn)橐粋€(gè)環(huán)境只能配置一個(gè).xcconfig文件:

image

而且,此時(shí)更新Pods也會(huì)警告:已經(jīng)存在其他的配置文件,Pods設(shè)置的.xcconfig文件不會(huì)生效;

解決方案:在自定義配置文件中使用關(guān)鍵include命令,引入pods的配置文件,使其生效:

//注意:這里需要根據(jù)debug、release等不同的環(huán)境,分別設(shè)置
#include "Pods/Target Support Files/Pods-TestProject/Pods-TestProject.debug.xcconfig"
6.xcconfig關(guān)鍵字沖突問題

Pods生成的.xcconfig文件通過include導(dǎo)入自定義的配置文件中后,如果兩者都對(duì)同一個(gè)key進(jìn)行過配置,就會(huì)導(dǎo)致前者無效的問題。

比如,兩者都對(duì)相同的Other Link Flags進(jìn)行配置,查看Build Setting后,會(huì)發(fā)現(xiàn)Pods生成的.xcconfig沒有生效;

解決方案:使用inherited進(jìn)行繼承,在自定義配置文件中配置如下:

OTHER_LDFLAGS = $(inherited) -framework "AFNetworking"
7.測(cè)試.xcconfig多環(huán)境
  1. 在不同的.xcconfig定義不同的HOST_URL,并以類似上文的步驟在info.plist中增加配置;
  2. 切換到不同的configration下運(yùn)行項(xiàng)目,將會(huì)得到不同的HOST_URL;

參考鏈接

  1. 本文測(cè)試Demo地址
  2. iOS多Target開發(fā)相似App
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
禁止轉(zhuǎn)載,如需轉(zhuǎn)載請(qǐng)通過簡(jiǎn)信或評(píng)論聯(lián)系作者。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容