SwiftUI列表正在工作,但选择器不起作用

时间:2020-07-26 15:42:59

标签: list swiftui picker

我有这种看法。该列表通过显示数据可以正常工作。选取器无法正常工作。它不显示任何数据。两者使用相同的对象和功能。我不知道选择器不显示数据的原因。我想使用选择器。我放置“列表”只是为了尝试确定问题,但我仍然不知道。

 import SwiftUI

struct GameListPicker: View {

@ObservedObject var gameListViewModel = GameListViewModel()
@State private var selectedGameList = ""

var body: some View {
    
    VStack{        
    
        List(gameListViewModel.gameList){gameList in
        HStack {
            Text(gameList.gameName)
            }
        }
        .onAppear() {self.gameListViewModel.fetchData()}
    
        Picker(selection: $selectedGameList, label: Text("")){
        ForEach(gameListViewModel.gameList) { gameList in
            Text(gameList.gameName)
            }
        }
        .onAppear() {self.gameListViewModel.fetchData()}}
     }
}

这是GameListViewModel

import Foundation
import Firebase

class GameListViewModel: ObservableObject{

@Published var gameList = [GameListModel]()
let db = Firestore.firestore()

func fetchData() {

    db.collection("GameData").addSnapshotListener {(querySnapshot, error) in
    guard let documents = querySnapshot?.documents else {
      print("No documents")
      return
    }

    self.gameList = documents.map { queryDocumentSnapshot -> GameListModel in
      let data = queryDocumentSnapshot.data()
      let gameName = data["GameName"] as? String ?? ""
      return GameListModel(id: gameName, gameName: gameName)
      }
    }
  }
}

这是GameListModel

import Foundation

struct GameListModel: Codable, Hashable,Identifiable {

var id: String
//var id: String = UUID().uuidString
var gameName: String

}

在此先感谢您的帮助

1 个答案:

答案 0 :(得分:1)

Picker并非动态设计,因此在数据更新时不会刷新,请尝试在数据更改时强制重建选择器,如下所示

    Picker(selection: $selectedGameList, label: Text("")){
    ForEach(gameListViewModel.gameList) { gameList in
        Text(gameList.gameName)
        }
    }.id(gameListViewModel.gameList)       // << here !!