@Environment 是視圖用于從環(huán)境中讀取、響應(yīng)、調(diào)用特定值的屬性包裝器。它允許視圖訪(fǎng)問(wèn)由 SwiftUI 或應(yīng)用環(huán)境提供的數(shù)據(jù)、實(shí)例或方法,例如顏色模式、字體設(shè)置等。系統(tǒng)會(huì)自動(dòng)提供這些值,并根據(jù)需要進(jìn)行調(diào)整。
應(yīng)用場(chǎng)景
- 當(dāng)需要訪(fǎng)問(wèn)和響應(yīng)如界面樣式(暗模式/亮模式)、設(shè)備方向、字體大小等由系統(tǒng)或上層視圖提供的環(huán)境值時(shí)( 通常對(duì)應(yīng)值類(lèi)型)。
- 當(dāng)需要訪(fǎng)問(wèn)和調(diào)用 SwiftData 的 ModelContext 時(shí)(對(duì)應(yīng)引用類(lèi)型)。
- 當(dāng)需要使用系統(tǒng)提供的一些方法時(shí),比如
dismiss、openURL( 通過(guò) struct 的callAsFunction封裝的方法 )。
使用示例
下面是一個(gè)使用 @Environment 屬性包裝器的示例代碼:我們使用 @Environment(.colorScheme) 將 colorScheme屬性聲明為從環(huán)境中獲取當(dāng)前的顏色方案。根據(jù)顏色方案的值,我們?cè)O(shè)置不同的文本顏色和背景色。你可以嘗試切換模擬器的外觀(guān)(Light 或 Dark),以查看文本顏色和背景色是如何自動(dòng)根據(jù)環(huán)境變量的值而更新的。
import SwiftUI
struct ContentView: View {
@Environment(\.colorScheme) var colorScheme
var body: some View {
if colorScheme == .dark {
Text("Dark Mode")
.foregroundColor(.white)
.background(Color.black)
} else {
Text("Light Mode")
.foregroundColor(.black)
.background(Color.white)
}
}
}
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
ContentView()
.previewLayout(.sizeThatFits)
}
}