gpt4 book ai didi

xcode - @Published ObservedObjects SwiftUI 更新未发生

转载 作者:行者123 更新时间:2023-12-02 00:08:48 27 4
gpt4 key购买 nike

@Published ObservedObjects SwiftUI 更新未发生

我已经创建了一个非常基本的 ObservableObject 应用程序并且更新了一些绑定(bind)正确的,有些不是。我一定错过了一些简单的东西。只有两个 View -开始 View 和第二个 View 。我只使用 Text、Button 和 Toggle - 只是为了测试这个概念。

我想在 UserDefaults 中存储启动属性值。那部分似乎有效美好的。当我在第二页上进行更改时,它们会在该页面上更新,并且UserDefaults 已正确写入。然而,在返回开始 View 时,已发布的绑定(bind)不会更新。有趣的是,UserDefaults 已更新。

主视图仅显示绑定(bind)值和用户默认值。

开始 View :

import SwiftUI

struct ContentView: View {
@State private var showUtilities = false
@ObservedObject var userDefaultManager = UserDefaultsManager()

var body: some View {
NavigationView {
VStack{
Group { //group 1
Text("Published userDefaultManager.name:")
Text("\(UserUtilities().makeSubString(stringIn: self.userDefaultManager.name, count: 24))")
.padding(.bottom, 30)
.lineLimit(0)

Text("UserDefaults.standard.value:")
Text("\(UserUtilities().makeSubString(stringIn: UserDefaults.standard.value(forKey: "name") as! String, count: 24))")
.padding(.bottom, 30)
.lineLimit(0)

Text("Published userDefaultsManager.enableBiometrics:")
Text(String(self.userDefaultManager.enableBiometrics))
.padding(.bottom, 30)
.font(.headline)
} //group 1

Group { //group 2
Text("UserDefaults.standard.bool:")
Text(String(UserDefaults.standard.bool(forKey: AppDelegate.eb)))
.padding(.bottom, 30)
.font(.headline)
Button(action: {
self.showUtilities.toggle()
}) {
Text("Show Utilities")
}
.frame(width: 200)
.padding()
.font(.headline)
}//group 2

}//vstack
.navigationBarTitle("Read the Values")
.sheet(isPresented: $showUtilities) {
UserUtilities()
}
}
}
}

第二种观点:

import SwiftUI
import Combine

struct UserUtilities: View {
@ObservedObject var userDefaultManager = UserDefaultsManager()

var body: some View {
NavigationView {
VStack {
Toggle(isOn: self.$userDefaultManager.enableBiometrics) {
Text("Enable Biometric Login")
}
.padding(EdgeInsets(top: 50, leading: 50, bottom: 30, trailing: 50))

//this does not update
Text("Published name is \(UserUtilities().makeSubString(stringIn: self.userDefaultManager.name, count: 24))")
.padding(EdgeInsets(top: 0, leading: 0, bottom: 30, trailing: 0))

Text("UserDefaults name is \(UserUtilities().makeSubString(stringIn: UserDefaults.standard.value(forKey: "name") as! String, count: 24))")
.padding(EdgeInsets(top: 0, leading: 0, bottom: 30, trailing: 0))

\\this does not update
Text("Published enableBiometrics is " + String(self.userDefaultManager.enableBiometrics) )

Text("UserDefaults is " + String(UserDefaults.standard.bool(forKey: AppDelegate.eb)) )
.padding(.bottom, 20)

Button(action: {
self.userDefaultManager.name = UUID().uuidString
}) {
Text("Change the Published name")
}
.padding()
.font(.headline)

}
.navigationBarTitle("User Utilities", displayMode: .inline)
}
}//body

func makeSubString(stringIn: String, count: Int) -> String {
if stringIn.count > count {
let modString = stringIn.dropFirst(count)
let returnString = String(modString)
return returnString
}
return "can't get substring"
}
}

我的 UserDefault 管理器:

import SwiftUI
import Combine

class UserDefaultsManager: ObservableObject {
@Published var name = UserDefaults.standard.value(forKey: "name") as! String {
didSet {
UserDefaults.standard.set(self.name, forKey: "name")
}
}

@Published var enableBiometrics: Bool = UserDefaults.standard.bool(forKey: AppDelegate.eb) {
didSet {
UserDefaults.standard.set(self.enableBiometrics, forKey: AppDelegate.eb)
}
}
}

为了完整性 - 在 AppDelegate 中:

static let eb = "enablebiometrics"
@ObservedObject var userDefaultManager = UserDefaultsManager()

在 didFinishLaunchingWithOptions 中:

    if UserDefaults.standard.value(forKey: AppDelegate.eb) == nil {
UserDefaults.standard.set(false, forKey: AppDelegate.eb)
}

userDefaultManager.enableBiometrics = UserDefaults.standard.bool(forKey: AppDelegate.eb)

if UserDefaults.standard.value(forKey: "name") == nil {
UserDefaults.standard.set("set in AppDelegate", forKey: "name")
}

userDefaultManager.name = UserDefaults.standard.value(forKey: "name") as! String

任何指导将不胜感激。 Xcode 11.3 (11C29)

最佳答案

您正在使用 UserDefaultsManager 的 2 个实例。仅实例化它并将其传递给第二个 View 或将其添加到环境 (@EnvironmentObject) 以在所有 View 中访问它。

您可以在 https://www.hackingwithswift.com/quick-start/swiftui/how-to-use-environmentobject-to-share-data-between-views 找到如何做到这一点的一个很好的例子。 .

关于xcode - @Published ObservedObjects SwiftUI 更新未发生,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59728852/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com