Ios 获取数据Firebase/Swift之前加载的TableView

Ios 获取数据Firebase/Swift之前加载的TableView,ios,swift,firebase,Ios,Swift,Firebase,我有一个FireBase数据库,里面有一个产品表和另一个订单表,其中有这些产品的ID,我试图做的是根据订单表中的ID从产品表中获取产品,因为FireBase只允许我逐个获取产品,在获取orders表中引用的所有产品之前,将加载我的tableview 我是这样做的: struct Product: Decodable, Encodable{ var id: String? var ref: String var description: String var typ

我有一个FireBase数据库,里面有一个产品表和另一个订单表,其中有这些产品的ID,我试图做的是根据订单表中的ID从产品表中获取产品,因为FireBase只允许我逐个获取产品,在获取orders表中引用的所有产品之前,将加载我的tableview

我是这样做的:

struct Product: Decodable, Encodable{
    var id: String?
    var ref: String
    var description: String
    var type: String
    var price: String
    var qtyOrdred:Int?
}

struct Order:Decodable, Encodable {

    var id: String?
    var isValide: Bool
    var madeBy: String
    var info: String?
    var ordredProd: [OrderedProduct]

}

struct OrderedProduct:Decodable, Encodable {
    var id: String
    var qty: Int
}

 func getData(completion: @escaping ([Product])->Void){
        var allProduct = [Product]()
        for product in orderedProduct {
            getProductWithKey(qty: product.qty, key: product.id) { (p) in
                print(p.ref)
                allProduct.append(p)
            }
}
}

func getProductWithKey(qty: Int,key: String, completion: @escaping (Product)->Void) {
    Database.database().reference().child("products").child(key).observeSingleEvent(of: .value) { (snap) in
        if let productObject = snap.value as? [String: Any]
        {
            if let ref  = productObject["ref"],
                let price  = productObject["price"],
                let type = productObject["type"],
                let description = productObject["description"],
                let id = productObject["id"]{
                let p = Product(id: id as? String, ref: ref as! String, description: description as! String, type: type as! String, price: price as! String, qtyOrdred: qty)
                completion(p)
            }
        }
    }
}
我这样称呼它:

override func viewWillAppear(_ animated: Bool) {
        self.getData { (ps) in
            print(ps)
            self.tableView.reloadData()
        }
    }

问题是它总是打印一个空数组,并且我的tableview数据从不更改

如果您没有从
getData
完成返回,您需要一个调度组

let g = DispatchGroup()
func getData(completion: @escaping ([Product])->Void){
     var allProduct = [Product]()
     for product in orderedProduct { 
        g.enter()
        getProductWithKey(qty: product.qty, key: product.id) { (p) in
            print(p.ref)
            allProduct.append(p)
            g.leave()
        }
     }  
     g.notify(queue:.main) {
        completion(allProduct)
     }
}

您不需要从
getData
completion返回,您需要一个调度组

let g = DispatchGroup()
func getData(completion: @escaping ([Product])->Void){
     var allProduct = [Product]()
     for product in orderedProduct { 
        g.enter()
        getProductWithKey(qty: product.qty, key: product.id) { (p) in
            print(p.ref)
            allProduct.append(p)
            g.leave()
        }
     }  
     g.notify(queue:.main) {
        completion(allProduct)
     }
}

for循环一完成,getData函数就返回。由于循环内的调用是异步的,因此循环完成时没有任何数据

与其重新加载表,不如在行到达时插入行

for product in orderedProduct {
   getProductWithKey(qty: product.qty, key: product.id) { [weak self] (p) in

      guard let self = self else { return }
      allProduct.append(p)
      guard let index = allProduct.firstIndex(of: p) else { return }
      self.tableView.insertRow(at: IndexPath(row: index, section: 0))
   }
}

for循环一完成,getData函数就返回。由于循环内的调用是异步的,因此循环完成时没有任何数据

与其重新加载表,不如在行到达时插入行

for product in orderedProduct {
   getProductWithKey(qty: product.qty, key: product.id) { [weak self] (p) in

      guard let self = self else { return }
      allProduct.append(p)
      guard let index = allProduct.firstIndex(of: p) else { return }
      self.tableView.insertRow(at: IndexPath(row: index, section: 0))
   }
}