问题描述
我有两个视图,嵌入在 TabView 中。 我在名为 usersettings 的类中使用 userdefaults。
class UserSettings: ObservableObject {
@Published var favList: [String] {
willSet {
print("willset")
}
didSet {
UserDefaults.standard.set(favList,forKey: "isAccountPrivate")
print("didset")
}
}
init() {
self.favList = UserDefaults.standard.object(forKey: "isAccountPrivate") as? [String] ?? ["Sepetiniz Boş"]
}
}
在按钮视图中,其作用类似于添加/删除收藏夹。它成功地从 UserDefaults 添加和删除。但是当我添加一些东西时,它不会显示在另一个视图上(请参阅 FavButton 之后的下一个代码)
struct FavButton: View {
@Binding var passedFood: String
@Observedobject var userSettings = UserSettings()
var body: some View {
Button(action: {
if userSettings.favList.contains(passedFood) {
userSettings.favList.remove(at: userSettings.favList.firstIndex(of: passedFood )!)
} else {
userSettings.favList.append(passedFood)
}
})
}
}
但除非我关闭并打开我的应用程序,否则它不会更新我在另一个视图中的列表。如果我从列表中删除某些内容,它实际上会从用户默认值中删除。
我唯一的问题是当我从另一个视图 (FavButton) 添加某些内容时,它不会显示在此视图 (FavView) 中。
struct FavView: View {
@Observedobject var userSettings = UserSettings()
@State private var newWord = ""
var body: some View {
NavigationView {
List {
TextField("Ürün Ekleyin...",text: $newWord,onCommit: addNewWord)
ForEach( self.userSettings.favList,id: \.self) { list in
Text(list)
.font(.headline)
.padding()
}
.onDelete(perform: self.deleteRow)
}
.navigationTitle("Sepetim")
}
}
private func deleteRow(at indexSet: IndexSet) {
self.userSettings.favList.remove(atOffsets: indexSet)
}
private func addNewWord() {
let answer = newWord.lowercased().trimmingCharacters(in: .whitespacesAndNewlines)
self.userSettings.favList.append(answer)
guard answer.count > 0 else {
return
}
newWord = ""
}
}
解决方法
遵循 SwiftUI 习惯用法的更好方法是使用 .environmentObject()
修饰符。
当您声明您的应用时:
struct AppScene: App {
@StateObject private var userSettings = UserSettings() // Use state object to persist the object
var body: some Scene {
WindowGroup {
ContentView()
.environmentObject(userSettings) // Inject userSettings into the environment
}
}
}
然后在您的体内ContentView
您可以进入您的环境并获取对象:
struct ContentView: View {
@EnvironmentObject private var userSettings: UserSettings
var body: some View {
Text("Number of items in favList: \(userSettings.favList.count)")
}
}
,
您需要在要观察用户设置的所有视图中使用相同的 UserSettings
实例,例如
class UserSettings: ObservableObject {
static let global = UserSettings()
//... other code
}
现在
struct FavButton: View {
@ObservedObject var userSettings = UserSettings.global // << here !!
// ... other code
}
和
struct FavView: View {
@ObservedObject var userSettings = UserSettings.global // << here !!
// ... other code
}