swift - 如何附加到 SwiftUI 中的数组?

标签 swift apple-watch environment swiftui watchos

在 SwiftUI 中追加到数组时遇到问题。

我正在使用 Xcode 11 beta 7 并使用更新的 ObservableObjectEnvironmentObjectPublished 语法 < strong>在 watchOS 应用程序上。 WKHostingController 需要具体类型,因此无法传递 ContentView().environmentObject(subject)

此行使应用程序崩溃:

self.subjectData.store.append(Subject(name: self.addedSubject, isFavorite: false)) 

有什么问题吗?

struct Subject: Codable, Identifiable {
    var id: UUID = UUID()
    var name: String
    var isFavorite: Bool
}

class SubjectDataEnv: ObservableObject {
    @Published var store = [
        Subject(name: "Physics", isFavorite: true),
        Subject(name: "Science", isFavorite: false)
    ]
    @Published var selectedSubject = Subject(name: "Subject 1", isFavorite: false)
}

class HostingController: WKHostingController<ContentView> {
    override var body: ContentView {
        return ContentView()
    }
}

struct ContentView: View {
    @State var subjectData = SubjectDataEnv()

    var body: some View {
        SubjectView().environmentObject(subjectData)
    }
}

struct SubjectView: View {
    @EnvironmentObject var subjectData: SubjectDataEnv
    var body: some View {
        List {
            ForEach(subjectData.store) { subject in
                NavigationLink(destination: DurationView()
                    .environmentObject(self.subjectData)
                )
            }
            NavigationLink(destination: AddSubjectView()
                .environmentObject(self.subjectData)
            ) {
                Text("+")
            }
        }
    }
}

struct AddSubjectView: View {  
    @EnvironmentObject var subjectData: SubjectDataEnv
    @State var addedSubject: String = "subject"
    var body: some View {
        VStack(alignment: .leading, spacing: 0) {
            TextField("Add your subject", text: $addedSubject)
            Button(action: {
                self.subjectData.store.append(Subject(name: self.addedSubject, isFavorite: false))   // crashes the app
            }) {
                Text("Done")
            }
        }
    }
}

最佳答案

有两种可能的方法:

  1. Using AnyView
class HostingController: WKHostingController<AnyView> {
    override var body: AnyView {
        return AnyView(AddSubjectView().environmentObject(SubjectDataEnv()))
    }
}

result

这是输出(我在按钮中附加了一个 print):

print(self.subjectData.store)
Subject(id: 2F3745EE-752B-4C8C-8A4F-8C21E73B315C, name: "Physics", isFavorite: true)
Subject(id: 5A9CF711-F6BE-4854-8F58-35FD004B2419, name: "Science", isFavorite: false)
Subject(id: E2F6A25E-3BC0-4D17-9AEF-07286533D475, name: "👌🏻", isFavorite: false)
Subject(id: 62FA7D12-A3D5-4381-8232-F48268B433F1, name: "☺️", isFavorite: false)

注意新的 👌🏻☺️ 主题。

  1. Injecting the @EnvironmenObject in a "parent view"
class HostingController: WKHostingController<ContentView> {
    override var body: ContentView {
        return ContentView()
    }
}
struct ContentView: View {
    var body: some View {
        return AddSubjectView().environmentObject(SubjectDataEnv())
    }
}

后者会产生相同的结果。

关于swift - 如何附加到 SwiftUI 中的数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57729659/

相关文章:

watchkit - iOS WatchOS - WatchKit 应用程序和 WatchKit 应用程序扩展之间有什么区别?

scripting - 从批处理中调用 PowerShell,并检索脚本中设置的临时环境变量的新值?

ios - 闭包元组不支持 Xcode 9 Swift 4 中的解构

swift - 通用功能中未识别协议(protocol)一致性

flutter - 是否可以使用 Flutter 来创建 Watch OS 或 Android Wear 的东西?

php - mysqli_fetch_assoc()期望参数/调用成员函数bind_param()错误。如何获取并修复实际的mysql错误?

javascript - 部署到生产时设置开发环境标志并消除调试代码

ios - 如何使用 plist 将用户进度保存在数组 Swift 中

ios - UIGestureRecognizerState.Cancelled 与 UIGestureRecognizerState.Failed

ios - Apple Watch 上的推送通知