[SwiftUI 开发] 嵌套的ObservedObject中的更改不会更新UI

1. 发生问题的demo

业务逻辑代码

Swift 复制代码
class Address: ObservableObject {
    @Published var street = "123 Apple Street"
    @Published var city = "Cupertino"
}

class User: ObservableObject {
    @Published var name = "Tim Cook"
    @Published var address = Address()
}

struct ContentView: View {
    @ObservedObject var user = User()

    var body: some View {
        VStack {
            Text("Name: \(user.name)")
            Text("Address: \(user.address.street), \(user.address.city)")
            Button("Change Address") {
                user.address.street = "New York"
            }
        }
    }
}

当我有一个嵌套的ObservedObject时,嵌套对象的已发布属性的更改不会更新UI,直到父对象发生变化,才会刷新。

2. 修改后的代码

SwiftUI(更准确地说是Combine)只能看到值的变化,因此,它可以看到@Published结构实例的属性值的变化,而不能看到@Published类。

如果您希望基于这些嵌套对象的属性值的更改来更新Ul,则使用嵌套对象的结构实例。如果必须使用类实例,请使用另一种机制显式地通知更改。下面是使用struct代替class的NestedObject修改的代码

业务逻辑代码

Swift 复制代码
struct Address {
    var street = "123 Apple Street"
    var city = "Cupertino"
}

class User: ObservableObject {
    @Published var name = "Tim Cook"
    @Published var address = Address()
}

struct ContentView: View {
    @ObservedObject var user = User()

    var body: some View {
        VStack {
            Text("Name: \(user.name)")
            Text("Address: \(user.address.street), \(user.address.city)")
            Button("Change Address") {
                user.address.street = "New York"
            }
        }
    }
}

总结一句话,一个对象只需要当前属性@Published就可以了,子类使用struct

相关推荐
sakiko_1 天前
Swift学习笔记34-MVC架构,SwiftUI与UIkit混编练习
笔记·学习·swiftui·mvc·swift
sakiko_4 天前
Swift学习笔记33-多线程与UI渲染
笔记·学习·swiftui·swift
东坡肘子6 天前
从社区路标到生态基石:Dave Verwer 的新篇章 -- 肘子的 Swift 周报 #137
人工智能·swiftui·swift
Daniel_Coder10 天前
iOS Widget 开发-18:Widget 的 SwiftUI 视图适配与设计
ios·swiftui·swift·widget·widgetcenter
Daniel_Coder13 天前
iOS Widget 开发-12:Widget 深度链接与导航
ios·swiftui·swift·widget·intents
Daniel_Coder13 天前
iOS Widget 开发-11:Widget 交互按钮实战(iOS 17+ App Intents)
ios·swiftui·swift·widget·link·appintents
东坡肘子13 天前
消失的 WWDC 愿望单 -- 肘子的 Swift 周报 #136
人工智能·swiftui·swift
浩宇软件开发13 天前
SwiftUI入门 10 分钟学会做一个 App 引导页
ios·swiftui·swift
sakiko_16 天前
Swift报错合集(Xcode编译器)
开发语言·swiftui·xcode·swift·uikit
Joseph1818 天前
深度拆解 DanceUI:从声明式视图到原生渲染的全链路技术解析
ios·swiftui