Как читать данные из Firebase, блок с не работает? - PullRequest
2 голосов
/ 26 марта 2019

Я пытаюсь прочитать данные из firebase.Я сделал НаблюдатьSingleEvent, но блок "с" не работает, почему?

Я пытаюсь отладить и замечаю, что блок с не работает.ИД пользователя имеет правильный идентификатор и ссылку также правильно

    var ref: DatabaseReference!
    var snapData: NSDictionary?
    var nameString = [String]()

    override func viewDidLoad() {
        super.viewDidLoad()

        ref = Database.database().reference()
        loadData()
        table.delegate = self
        table.dataSource = self
        table.register(UITableViewCell.self, forCellReuseIdentifier: "indentifire")
        view.addSubview(table)


        // Do any additional setup after loading the view.
    }

    // ---------------------------------------------------

    //loading data from FireBase
    func loadData() {
        let userID = Auth.auth().currentUser?.uid
        ref.child("users").child(userID!).observeSingleEvent(of: .value, with: { (snapshot) in
            self.snapData = snapshot.value as? NSDictionary
        })
    }

    // delegate
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        var temp = 0
        for (_,val) in snapData! {
            if val as? String == "false" {
                temp += 1
                nameString.append(val as! String)
            }
        }
        return temp
    }

    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = table.dequeueReusableCell(withIdentifier: "indentifire", for: indexPath)
        cell.textLabel!.text = nameString[indexPath.row]
        return cell
    }```

this is my database
![photo](https://imgur.com/a/0UzOPJ7

1 Ответ

0 голосов
/ 26 марта 2019

Операции с базой данных работают асинхронно. Сопоставьте данные в loadData и перезагрузите представление таблицы

func loadData() {
    let userID = Auth.auth().currentUser?.uid
    ref.child("users").child(userID!).observeSingleEvent(of: .value, with: { (snapshot) in
        if let snapData = snapshot.value as? [String:Any] {
           self.nameString = snapData.values.compactMap {$0 as? String}
           DispatchQueue.main.async {
              self.table.reloadData()
           }
        }
    })
}

А в numberOfRowsInSection просто вернуть количество предметов в nameString

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return nameString.count
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...