为啥我的 SwiftUI 列表填充相同的项目 4 次而不是全部 4 个项目?

Posted

技术标签:

【中文标题】为啥我的 SwiftUI 列表填充相同的项目 4 次而不是全部 4 个项目?【英文标题】:Why is my SwiftUI List populating with the same item 4 times instead of all 4 items?为什么我的 SwiftUI 列表填充相同的项目 4 次而不是全部 4 个项目? 【发布时间】:2019-11-19 02:45:19 【问题描述】:

我正在从 Firestore 读取数据并将其解析为自定义模型 Thought

对于我的 Firestore 集合中的每个文档,我将一个新的 Thought 对象附加到 @Published var thoughts

struct Thought: Identifiable 

    public var id: String?
    public var name: String
    public var thought: String
    public var color: String


class Observer: ObservableObject 

    @Published var thoughts = [Thought]()

    init()
        let db = Firestore.firestore()

        db.collection("thoughts")
        .addSnapshotListener  querySnapshot, error in
            guard let documents = querySnapshot?.documents else 
                print("Error fetching documents: \(error!)")
                return
            

            for document in documents 

                var thoughtModel = Thought(id: "", name: "", thought: "", color: "")

                thoughtModel.name = document.data()["name"] as! String
                thoughtModel.thought = document.data()["thought"] as! String
                thoughtModel.color = document.data()["color"] as! String

                self.thoughts.append(thoughtModel)
            
            print(self.thoughts) //PRINTS 4 DIFFERENT THOUGHT OBJECTS
        
    


struct ThoughtsView: View 

    @ObservedObject var observer = Observer()

    var body: some View 
        VStack 
            List 
                ForEach(self.observer.thoughts)  thought in

                    ThoughtCard(color: thought.color,
                                thought: thought.thought,
                                name: thought.name)
                    //HERE I GET THE SAME CARD 4 TIMES INSTEAD OF 4 DIFFERENT CARDS
                
            
        
    

当我打印 thoughts 时,我看到了当前在我的 Firestore 数据库中的所有 4 个文档。但是,当我尝试遍历列表中的 thoughts 时,我只是相同的 Thought 对象 4 次,而不是 4 个不同的 Thought 对象。

我认为问题在于List 以及我如何迭代self.observer.thoughts,但我不确定我做错了什么。如何使用 self.observer.thoughts 中的 4 个对象填充列表?

【问题讨论】:

【参考方案1】:

我的列表确实有问题。添加id: 参数后,List 似乎能够识别每个Thought 对象并相应地显示它们。

struct ThoughtsView: View 

    @ObservedObject var observer = Observer()

    var body: some View 
        VStack 
            List 
                ForEach(self.observer.thoughts, id: \.name)  thought in

                    ThoughtCard(color: thought.color,
                                thought: thought.thought,
                                name: thought.name)
                
            
        
    

【讨论】:

以上是关于为啥我的 SwiftUI 列表填充相同的项目 4 次而不是全部 4 个项目?的主要内容,如果未能解决你的问题,请参考以下文章

为什么我的SwiftUI列表没有填充我的所有数据?

当列表填充数组时,如何在 SwiftUI 中获取列表中元素的索引?

如何从 Mac OS 中的 SwiftUI 列表中删除底部/顶部项目填充

为啥我的 SwiftUI 列表分隔符没有正确排列?

为啥我的绑定 [String] 不会更改我的多选列表 SwiftUI

SwiftUI MacOS 列表的 Inset 填充