SwiftUI 属性包装器系列 --- @State @Binding

@State

@State属性包装器在视图里面使用,允许视图对@State的属性进行响应。@State是视图本身初始化的属性。它不能获取另一个对象的@State属性的值。

less 复制代码
struct StateExample: View {
  @State private var intValue = 0
  @State private var modelObject = MyModelObject()

  var body: some View {
    VStack {
      Text("intValue equals (intValue)")
      Button("Increment") {
        intValue += 1
      }
    }
  }
}

SwiftUI会存储@State属性的值,并在视图重新渲染期间保存它的值。这使得@State非常适合用于视图本身的状态管理,因此在视图实例刷新(重构)的时候会保留状态。

请注意:将视图的@State属性标记private,从而防止任何外部修改视图的@State属性。

@State使用的注意事项:

  • 属性的类型通常是值类型(structenum)。
  • 在iOS 17+时可以包装一个@Observable的对象。
  • 视图本身创建(并拥有)的属性。
  • 需要响应某个属性发生的改变。

请注意,在引用类型 (class) 上使用 @State ,但更改实例本身的属性不会更新。即使您更改的属性是@Published 。在 iOS 17+ 上,用 @Observable注释的对象可以使用 @State并且会起到更新的作用。该@Observable宏使用一种特殊的机制将模型更改传达给视图。

@Binding

@Binding属性包装器用于视图属性的传递。接收绑定的视图能够读取绑定的属性,响应父视图所做的改变,并且拥有对该属性的读写。

接收@Binding属性的值并且点击按钮导致intValue改变的例子:

swift 复制代码
struct StateView: View {
  @State private var intValue = 0
  var body: some View {
    VStack {
      Text("intValue equals (intValue)")
      BindingView(intValue: $intValue)
    }
  }
}

struct BindingView: View {
  @Binding var intValue: Int

  var body: some View {
    Button("Increment") {
      intValue += 1
    }
  }
}

@State属性的值是可以传递给子视图,以便它们可以通过绑定修改属性而不是直接修改属性。在@Binding内部,当您的视图被丢弃时,值不会保留。因为@Binding总是由外部传值的。@State@Binding的区别就是当视图被丢弃并重新创建以进行新渲染时,其值仍然存在。

@Binding使用的注意事项:

  • 需要对父视图拥有的属性进行读写。
  • 属性是值类型(structenum)。(可以是引用类型 ( class),但它并不常见。)
  • 不拥有属性的值状态(它由父视图提供)。
相关推荐
zhyongrui15 小时前
SnipTrip 菜单 Liquid Glass 实现方案:结构、材质、交互与深浅色策略
ios·性能优化·swiftui·交互·开源软件·材质
zhyongrui16 小时前
SnipTrip 不发烫的实现路径:局部刷新 + 合成缓存 + 峰值削减
ios·swiftui
初级代码游戏1 天前
iOS开发 SwiftUI 14:ScrollView 滚动视图
ios·swiftui·swift
初级代码游戏1 天前
iOS开发 SwitftUI 13:提示、弹窗、上下文菜单
ios·swiftui·swift·弹窗·消息框
zhyongrui2 天前
托盘删除手势与引导体验修复:滚动冲突、画布消失动画、气泡边框
ios·性能优化·swiftui·swift
zhangfeng11332 天前
CSDN星图 支持大模型微调 trl axolotl Unsloth 趋动云 LLaMA-Factory Unsloth ms-swift 模型训练
服务器·人工智能·swift
zhyongrui3 天前
SnipTrip 发热优化实战:从 60Hz 到 30Hz 的性能之旅
ios·swiftui·swift
大熊猫侯佩3 天前
Neo-Cupertino 档案:撕开 Actor 的伪装,回归 Non-Sendable 的暴力美学
swift·observable·actor·concurrency·sendable·nonsendable·data race
大熊猫侯佩3 天前
赛博深渊(上):用 Apple Foundation Models 提炼“禁忌知识”的求生指南
llm·swiftui·大语言模型·foundationmodel·apple ai·apple 人工智能·summarize
zhyongrui5 天前
SwiftUI 光晕动画性能优化:消除托盘缩放卡顿的实战方案
ios·性能优化·swiftui