iOS?xcconfig編寫示例教程
引言
xcconfig
文件的語法比較簡單,每個配置文件都由一系列鍵值分配組成,這些鍵值分配具有以下語法:
BUILD_SETTING_NAME = value
注釋
xcconfig
文件只有一種注釋方式,就是//
。
include導入其他設置
在創(chuàng)建xcconfig
文件的時候,可以根據(jù)需求,創(chuàng)建多個。也就意味著,可以通過include
關(guān)鍵字導入其他的xcconfig
內(nèi)的配置。通過include
關(guān)鍵字后接上雙引號,如下例:
#include "Debug.xcconfig"
在搜索引入的文件時,如果是以/
開頭,代表絕對路徑,例如:
// 表示確切的文件位置 #include "/Users/ws/Desktop/LoginApp-沖突/Pods/Target Support Files/Pods-LoginApp/Pods-LoginApp.debug.xcconfig"
或者通過相對路徑,以${SRCROOT}
路徑為開始:
#include "Pods/Target Support Files/Pods-LoginApp/Pods-LoginApp.debug.xcconfig"
變量
變量定義,按照OC
命名規(guī)則,僅由大寫字母,數(shù)字和下劃線(_
)組,原則上大寫,也可以不。字符串可以是"
也可以是'
號。
變量有三種特殊情況:
- 在
xcconfig
中定義的變量與Build Settings
的一致,那么會發(fā)生覆蓋。可以通過$(inherited)
,讓當前變量繼承變量原有值。例如:
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
對設置進行條件化,例如:
// 指定`Configration`是`Debug` // 指定`SDK`是模擬器,還有iphoneos*、macosx*等 // 指定生效架構(gòu)為`x86_64` OTHER_LDFLAGS[config=Debug][sdk=iphonesimulator*][arch=x86_64]= $(inherited) -framework "Cat"
注意??:在Xcode 11.4
及以后版本,可以使用default
,來指定變量為空時的默認值:
$(BUILD_SETTING_NAME:default=value)
優(yōu)先級(由高到低)
- 手動配置
Target Build Settings
Target
中配置的xcconfig
文件- 手動配置
Project Build Settings
Project
中配置的xcconfig
文件
以上就是iOS xcconfig編寫示例教程的詳細內(nèi)容,更多關(guān)于iOS xcconfig編寫的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解iOS應用開發(fā)中Core Data數(shù)據(jù)存儲的使用
這篇文章主要介紹了iOS應用開發(fā)中Core Data數(shù)據(jù)存儲的使用,Core Data可以看作是一個內(nèi)嵌型數(shù)據(jù)庫SQLite的iOS專用版本,需要的朋友可以參考下2016-02-02