SwiftUI:屬性包裝器@Environment的使用示例

@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í),比如 dismissopenURL( 通過(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)
    }
}
?著作權(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)容僅代表作者本人觀(guān)點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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