@Environment 是視圖用于從環(huán)境中讀取盖袭、響應(yīng)仍秤、調(diào)用特定值的屬性包裝器。它允許視圖訪問由 SwiftUI 或應(yīng)用環(huán)境提供的數(shù)據(jù)诗力、實例或方法凰浮,例如顏色模式、字體設(shè)置等苇本。系統(tǒng)會自動提供這些值,并根據(jù)需要進行調(diào)整劝贸。
應(yīng)用場景
- 當需要訪問和響應(yīng)如界面樣式(暗模式/亮模式)、設(shè)備方向禁灼、字體大小等由系統(tǒng)或上層視圖提供的環(huán)境值時( 通常對應(yīng)值類型)弄捕。
- 當需要訪問和調(diào)用 SwiftData 的 ModelContext 時(對應(yīng)引用類型)。
- 當需要使用系統(tǒng)提供的一些方法時平酿,比如
dismiss
棍辕、openURL
( 通過 struct 的callAsFunction
封裝的方法 )栋荸。
使用示例
下面是一個使用 @Environment 屬性包裝器的示例代碼:我們使用 @Environment(.colorScheme) 將 colorScheme屬性聲明為從環(huán)境中獲取當前的顏色方案。根據(jù)顏色方案的值匆背,我們設(shè)置不同的文本顏色和背景色呼伸。你可以嘗試切換模擬器的外觀(Light 或 Dark),以查看文本顏色和背景色是如何自動根據(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)
}
}