首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

更改@State变量不会更新SwiftUI中的视图

在SwiftUI中,@State变量是一种特殊的属性包装器,用于在视图中存储和管理可变的状态。当@State变量的值发生更改时,SwiftUI会自动重新计算并更新相关的视图。

然而,有时候更改@State变量的值并不会立即更新视图。这可能是由于以下几个原因:

  1. 视图层次结构:如果更改@State变量的代码位于视图层次结构中的某个子视图中,而不是直接位于父视图中,那么父视图可能不会重新计算和更新。这是因为SwiftUI使用了一种称为"视图身份"的优化技术,只有当父视图的身份发生变化时,才会重新计算和更新子视图。为了解决这个问题,可以尝试在更改@State变量的代码所在的父视图上使用@State属性包装器。
  2. 值类型:如果@State变量是一个值类型(如结构体或枚举),并且更改的是该值类型的某个属性,而不是整个变量本身,那么视图可能不会更新。这是因为SwiftUI在比较值类型时,只会比较它们的引用,而不会比较它们的属性。为了解决这个问题,可以尝试在更改@State变量时创建一个新的值类型实例。
  3. 异步更新:如果更改@State变量的代码是在异步任务中执行的,那么视图可能不会立即更新。这是因为异步任务可能在后台线程中执行,而视图更新必须在主线程上进行。为了解决这个问题,可以使用DispatchQueue.main.async将更改@State变量的代码包装在主线程上。

总结起来,要确保更改@State变量后能够更新SwiftUI中的视图,可以尝试以下几个方法:

  1. 将更改@State变量的代码放在父视图上,并使用@State属性包装器。
  2. 如果更改的是值类型的属性,尝试创建一个新的值类型实例。
  3. 如果更改代码是在异步任务中执行的,使用DispatchQueue.main.async将其包装在主线程上。

对于SwiftUI中的视图更新问题,腾讯云没有直接相关的产品或链接。但腾讯云提供了丰富的云计算服务,如云服务器、云数据库、云存储等,可以在开发过程中使用这些服务来支持应用程序的部署、数据存储和管理等方面的需求。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

避免 SwiftUI 视图重复计算

原文发表于我博客 肘子 Swift 记事本 视图状态构成 可以驱动视图进行更新源被称之为 Source of Truth,它类型有: 使用 @State、@StateObject 这类属性包装器声明变量...仅被保存在 State 实例内部属性 _value ,此时,使用 Stae 包装变量值没有被保存在 SwiftUI 托管数据池中,并且 SwiftUI 也尚未在属性图中将其作为 Source...当 SwiftUI视图视图树上删除时,会一并完成对 SwiftUI 数据池以及关联清理工作。如此,使用 State 包装变量,其存续期将与视图存续期保持完全一致。...并且 SwiftUI 会在其变化时自动更新( 重新计算 )对应视图SwiftUI 上有一个困扰了不少人问题:为什么无法在视图构造函数更改 State 包装变量值?...当触发器接收到事件后,无论其是否更改当前视图其他状态,当前视图都会被更新

9.3K81

SwiftUI 实现视图居中若干种方法

访问我博客 www.fatbobman.com[1] 可以获得更好阅读体验以及最新更新内容。...在 SwiftUI ,有很多手段可以达成此目的。本文将介绍其中一些方法,并对每种方法背后实现原理、适用场景以及注意事项做以说明。...HStack、VStack 是不会给 Spacer 分配 spacing ,毕竟 Spacer 本身就代表了空间占用。...().fill(.clear)在使用 SwiftUI 进行开发过程,Color、Rectangle 等经常被用来实现对容器等分操作。...我为本文这种通过多种方法来解决一个问题方式添加了【小题大作】标签,目前使用该便签文章还有:在 Core Data 查询和使用 count 若干方法[6]、在 SwiftUI 视图中打开 URL

6.7K40
  • SwiftUI accessibilityChildren 视图修饰符作用

    前言SwiftUI 为我们提供了一系列丰富视图修饰符,用于操作视图可访问性树。我已经介绍了其中许多,你可以在博客中找到它们。...SwiftUI 不会渲染我们通过 ViewBuilder 闭包传递视图,它仅用于填充可访问性树子元素。...accessibilityChildren 和 accessibilityRepresentation 视图修饰符之间主要区别在于前者不会影响视图本身。...在上述代码,将柱状图填充颜色设为红色。您可以根据需要自行更改填充颜色。运行截图:总结今天,我们了解了 SwiftUI 为我们提供又一个强大可访问性视图修饰符。...SwiftUI 凭借提供如此多友好 API,简化了我们为了使我们应用对每个人都具有可访问性而必须做工作,做得非常出色。

    11820

    SwiftUI-数据流

    数据处理基本原则 Data Access as a Dependency:在 SwiftUI 数据一旦被使用就会成为视图依赖,也就是说当数据发生变化了,视图展示也会跟随变化,不会像 MVC 模式下那样要不停同步数据和视图之间状态变化...5.1 新特性 Property Wrapper来实现一种属性装饰语法糖(修饰器/装饰器) Property 这种形式最简单,就是在 View定义常量或者变量,然后在内部使用 import SwiftUI...不过值类型在传递时会发生复制操作,所以给传递后值类型即使属性更新了也不会触发最初传过来值类型重新赋值,所以界面并不会刷新,此时需要用@Binding,因为它可以将值类型转为引用类型,这样在传递时...数据流图 从上图可以看出SwiftUI 数据流转过程: 用户对界面进行操作,产生一个操作行为 action 该行为触发数据状态改变 数据状态变化会触发视图重绘 SwiftUI 内部按需更新视图,...最终再次呈现给用户,等待下次界面操作 注意 在 SwiftUI ,开发者只需要构建一个视图可依赖数据源,保持数据单向有序流转即可,其他数据和视图状态同步问题 SwiftUI 帮你管理,所以 ViewController

    10.1K20

    SwiftUI数据流之State&Binding

    SwiftUI,以单一数据源(single source of truth)为核心,构建了数据驱动状态更新机制。...类不需要mutating关键字,因为即使类实例被标记为常量,Swift仍然可以修改变量属性。 如果User是一个类,属性本身就不会改变,所以@State不会注意到任何东西,也无法重新加载视图。...即使类内某个属性值发生变化,但@State不监听这些,所以视图不会被重新加载。...@Binding作用是在保存状态属性和更改数据视图之间创建双向连接,将当前属性连接到存储在别处单一数据源(single source of truth),而不是直接存储数据。...通常使用场景是把当前View@State值类型传递给其子View,如果直接传递@State值类型,将会把值类型复制一份copy,那么如果子View对值类型某个属性进行修改,父View不会得到变化

    4.1K30

    Swift 掌握 Observation 框架

    之后,我们可以观察 Store 类型任何变量。我们在 Store 类型只有一个变量,用于定义存储状态。另一个字段是一个永不更改 let 常量。...在第一个闭包,我们可以访问可观察类型所有必要属性。观察框架仅在触摸到观察类型任何属性更改后才调用第二个闭包。...SwiftUI 自动跟踪在 SwiftUI ,你不需要使用 withObservationTracking 函数来观察更改SwiftUI 自动跟踪视图正文中使用任何可观察类型属性更改。...SwiftUI 自动执行此操作。只要存储状态属性更改SwiftUI 就会更新视图。...我们不需要 @ObservedObject 属性包装器来跟踪可观察类型更改,但我们仍然需要 @StateObject 替代项以在 SwiftUI 生命周期中存活。

    23421

    SwiftUI 与 Core Data —— 数据获取

    类型可引发视图更新数据发生变化后调用该方法。...不可在 update 方法同步地改变引发视图更新数据与 SwiftUI视图更新 Source of truth 逻辑一致,在一个视图更新周期中,不能对 Source of truth 再度更新...这意味着,尽管我们只能在 update 方法更改数据,但必须要想办法错开该更新周期。...,避免引发视图不必要更新通过创建一个具有包装用途引用类型来持有需要修改数据( 在 @State 持有引用 ),便可以达成如下目的:1、让数据生命周期与视图生存期一致;2、数据可更改;3、更改数据不会引发视图更新...这是由于一旦 SwiftUI 惰性容器中出现了多个 ForEach ,惰性容器将丧失对子视图优化能力。任何数据变动,惰性容器都将对所有的子视图进行更新而不是仅更新可见部分视图

    4.6K30

    SwiftUI @State @Published @ObservedObject 深入理解和使用

    @State 介绍 因为SwiftUI View 采用是结构体,当创建想要更改属性结构体方法时,我们需要添加mutating关键字,例如: mutating func doSomeWork() 然而...@State允许我们绕过结构体限制:我们知道不能更改它们属性,因为结构是固定,但是@State允许SwiftUI将该值单独存储在可以修改地方。...提示:在SwiftUI存储程序状态有几种方法,您将学习所有这些方法。@State是专门为存储在一个视图简单属性而设计。...因为SwiftUI更新数据前提是触发 第一层 绑定对象 wrapperModel下属性(字段)发生更新才会调用视图更新数据 但是 第一次下绑定对象还绑定了 @ObservedObject 或者其他类型对象呢...还会触发第一次对象属性更新吗,答案是不能 你可以在 didSet 事件里面捕捉,是捕捉不到,所以视图不会更新,那这还有其他解决方案吗 有: 调用对象 wrapperModel.objectWillChange.send

    3.2K10

    SwiftU:将状态绑定到UI控件

    SwiftUI@State属性包装器允许我们自由修改视图结构体,这意味着当程序更改时,我们可以更新视图属性以匹配。 但是,使用UI控件时,事情会更复杂一些。...但是,该代码不会编译,因为SwiftUI想知道文本字段文本存储位置。 请记住,视图是其状态函数——文本输入框只能在反映存储在程序值时显示某些内容。...SwiftUI需要是结构一个字符串属性,它可以显示在文本输入框,还将存储用户在文本输入框中键入任何内容。...但是,该代码仍然无法工作,因为Swift需要能够更新name属性以匹配用户在文本字段中键入任何内容,因此您可以使用`@State``,如下所示: @State private var name = "...问题是Swift区分了“在此处显示此属性值”和“在此处显示此属性值,但将任何更改写回该属性” 在Swift,我们用一个特殊符号来标记这些双向绑定,这样它们就很显眼:我们在它们前面写一个美元符号$

    2.9K10

    SwiftUI 动画进阶 — Part4:TimelineView

    为了解决这个问题,我们更改了 SubView 视图以添加一个参数,该参数将随着时间轴每次更新而改变。请注意,我们不需要使用参数,它只需要在那里。尽管如此,我们将看到这个未使用值稍后会非常有用。...笔者将在本节中介绍技术,使用我们已熟知动画并且热衷于视图动画从一个时间线更新到下一个时间线。这最终将让我们在纯 SwiftUI 创建我们自己类似关键帧动画。...每次时间线更新都必须刷新唯一视图是 MetronomePendulum,它可以左右摆动。其他视图不会刷新,因为它们没有依赖关系。...除了在每次日期值更改时推进动画阶段,我们还在 onAppear 闭包执行此操作。否则,一开始就会有停顿。 最后一段与 SwiftUI 无关代码是创建 NSSound 实例。...使用 onChange 和 onAppear 推进动画,使用 @State 变量来跟踪动画,并设置一个动画,将我们视图从一个时间线更新过渡到下一个。

    3.8K30

    SwiftUI 作用域动画

    前言从一开始,动画就是 SwiftUI 最强大功能之一。你可以在 SwiftUI 快速构建流畅动画。...我们将动画视图修饰符附加到整个堆栈,以动画堆栈内任何更改。当我们按下按钮时,堆栈会动画显示内部任何更改。...但是,动画视图修饰符不连接到 isHidden 属性,这意味着它将动画显示可能发生任何更改。其中一些更改可能是意外,比如环境值变化。...动画视图修饰符我们可以通过使用动画视图修饰符另一个版本来消除意外动画,在这个版本,我们可以绑定到特定值,并且仅在值更改时进行动画处理。...总结这篇文章介绍了在SwiftUI构建动画新方法,重点解决了在多步动画或特定视图层次结构控制动画挑战。

    16910

    SwiftU:在循环中创建视图

    SwiftUI为此提供了一个专用视图类型,称为ForEach。这可以在数组和范围上循环,根据需要创建尽可能多视图。更妙是,ForEach不会像我们手动输入视图一样被10个视图限制所影响。...为了证明这一点,我们将定义一个视图: 1、有一系列可能学生名字。 2、具有一个@State属性存储当前选定学生。...3、创建一个Picker视图,要求用户选择他们最喜欢,并将选择值和@State属性双向绑定。 4、使用ForEach循环遍历所有可能学生姓名,将其转换为文本视图。...2、selectedStudent属性初始值为0,但可以更改,这就是为什么它标记为@State原因。...4、Picker与selectedStudent有双向绑定,这意味着它将开始显示0选择,但是在用户滑动选择器时更新属性。 5、在ForEach,我们从0数到(但不包括)数组学生数。

    2.2K20

    打造可适配多平台 SwiftUI 应用

    horizontalSizeClass 发生变化时,及时更新我们自定义 deviceStatus。...由于 iPhone 只支持单窗口模式,通常我们不会太注意它存在,但在 iPadOS 以及 macOS 这些支持多窗口系统,则代表着,每次创建一个新窗口(在 macOS ,通过菜单新建来创建新窗口...我将通过另一个简单应用来展示这种场景。 我想很多读者此时都不会太赞同在每个场景创建一个独立 Store 实例这种做法。...,而设置视图不会像 iPhone 和 iPad 那样一并随之变化。...在 iOS ,我们通过在根视图( ContentView )修改环境值方式来更改颜色和语言,并不会对 macOS Settings 场景产生影响。

    2K10

    一段因 @State 注入机制所产生“灵异代码”

    这意味着,即使我们在定义视图结构体声明了使用 @State 标注变量,但只要 body 没有使用该属性( 通过 ViewBuilder 支持语法 ),即使该属性发生变化,视图不会刷新。...当在 Text 添加 n 引用后,每次 n 值发生变化,都将引发视图更新。...也就是说 Sheet 视图与原有视图分别处于不同上下文中。在 SwiftUI 早期版本,对于分别位于不同上下文独立视图树,开发者需要显式为 Sheet 视图树注入环境依赖。...State 声明,但 show 变化并不会导致 ContextView 重新更新。...这是因为在 .fullScreenCover 构造方法,我们传递是 show projectedValue( Binding 类型 )由于合并操作原因,在 Sheet 视图关联到 n 后,并不会重新更新

    1.9K20

    Ask Apple 2022 与 SwiftUI 有关问答(上)

    contextMenu_2022-10-26_14.01.21.2022-10-26 14_02_29如何对 @State 变量进行测试Q:对于测试 SwiftUI 视图 @State 变量是否有推荐方式...只有将这些变量重构到视图模型中去这一种方式?A:如果在同一个视图中,有多个相互关联 @State 属性,将他们提取到一个结构或许是好选择。...对于苹果工程师给予建议有一点请注意,那就是如果有在父视图中修改该环境对象实例需求,须确保父视图不会被反复重构( SwiftUI 重新创建视图类型实例 )。...场景内容视图定义了场景创建窗口中视图内容,但场景本身定义了应用程序整体结构。SwiftUI 4.0 ,WindowGroup 获得了相当大更新,真正具备了开发 macOS 应用能力。...官方文档主要试图指出人们最常见用法,这样他们就不会一开始就试图直接初始化他们属性包装器。顺便提一下,试图通过底层存储来初始化 @State 是我们在过去警告过事情。

    12.2K20

    SwiftUI Release 引入辅助焦点管理

    这个新功能使得在SwiftUI处理辅助技术(如 VoiceOver 和 Switch Control)焦点状态变得更加轻松。...SwiftUI 默认使用 false 值初始化该变量,因为用户可以聚焦屏幕任何其他区域。我们还使用 focused 视图修饰符将特定视图焦点状态绑定到保存其值变量。...使用 @FocusState 属性包装器定义了可选变量 focus,以便在用户将焦点从您定义视图移动时将其值设置为 nil。...请记住,您可以通过更改 @FocusState 包装变量值来以编程方式移动 VoiceOver 或 Switch Control 焦点。...通过详细示例代码,我们演示了如何在 SwiftUI 中使用 @FocusState,以及如何通过 focused 视图修饰符将焦点状态绑定到特定视图

    11410
    领券