SwiftUI 属性包装器系列 --- @Environment @EnvironmentObject

@Environment

SwiftUI 使用环境 来传递系统范围的设置,如ContentSizeCategory、LayoutDirection、ColorScheme 等

@Environment用于从环境中读取值。如果环境中的值发生变化,您的视图就会更新。不能使用此属性包装器来设置或修改环境属性。

1、环境中读取值:

swift 复制代码
struct MyView: App {
  @Environment(.colorScheme) var colorScheme: ColorScheme
  var body: some View {
    Text("The color scheme is (colorScheme == .dark ? "dark" : "light")")
  }
}

2、要在视图上设置@Environment属性,需要使用.environment视图修饰符。:

scss 复制代码
ContentView()
    .environment(.managedObjectContext, Persistence.shared.viewContext)

3、自定义属性添加到视图的环境中,如下所示:

swift 复制代码
//枚举
enum AppStyle {
    case classic, 
    case modern,
}
// 设置默认枚举
private struct AppStyleKey: EnvironmentKey {
    static let defaultValue = AppStyle.modern
}
// 注册枚举key 到环境里
extension EnvironmentValues {
    var appStyle: AppStyle {
        get { self[AppStyleKey.self] }
        set { self[AppStyleKey.self] = newValue }
    }
}
// 使用
ContentView().environment(.appStyle, .classic)

@EnvironmentObject

SwiftUI 的@EnvironmentObject属性包装器允许我们创建依赖于共享数据的视图,通常使用在整个应用程序。

有时应用程序中的各个位置都需要某个对象,并且不希望用传递参数的方式给创建的每个视图的初始值设定项。

标记为@EnvironmentObject的属性必须符合ObservableObject. 它们由@EnvironmentObject使用.

scss 复制代码
class UserInfo: ObservableObject {
    @Published var name = ''
}
struct EnvironmentUsingView: View {
  @EnvironmentObject var userInfo: UserInfo
  var body: some View {
    Text(userInfo.name)
  }
}

要在视图上设置@Environment属性,需要使用.environmentObject视图修饰符。:

scss 复制代码
struct MyApp: App {
  @StateObject var userInfo: UserInfo
  var body: some Scene {
    WindowGroup {
      EnvironmentUsingView()
        .environmentObject(userInfo)
    }
  }
}

@EnvironmentObject@ObservedObject共同点:

  • 两者必须引用符合ObservableObject的类,
  • 两者可以在多个视图之间共享,并且两者都会在发生重大更改时更新正在观察的任何视图。

注意: 当显示@EnvironmentObject视图时,SwiftUI将立即在环境中搜索正确类型的对象。如果找不到这样的对象(情况:忘记将其放置在环境中),那么应用程序将立即崩溃。

相关推荐
Swift社区4 天前
LeetCode 391 完美矩形 - Swift 题解
算法·leetcode·swift
升讯威在线客服系统5 天前
从 GC 抖动到稳定低延迟:在升讯威客服系统中实践 Span 与 Memory 的高性能优化
java·javascript·python·算法·性能优化·php·swift
Swift社区5 天前
LeetCode 390 消除游戏 - Swift 题解
leetcode·游戏·swift
东坡肘子6 天前
春晚、机器人、AI 与 LLM -- 肘子的 Swift 周报 #124
人工智能·swiftui·swift
君赏7 天前
第三十二章 接下来我们开始做`灭菌整板`页面
swiftui
君赏7 天前
第三十章 接下来我们写首页的功能,首先是我们的`托盘绑定箱号`。
swiftui
君赏7 天前
第三十一章 完善箱号列表
swiftui
君赏7 天前
第二十五章 完善登录逻辑
swiftui
君赏7 天前
第二十六章 Focused
swiftui
君赏7 天前
第 二十章 @Published sink
swiftui