UICollectionView не обновляется при получении данных - PullRequest
0 голосов
/ 23 сентября 2018

Может кто-нибудь помочь?Функция fetchUser() работает, и я вижу, что пользователи загружаются, но ячейки представления коллекции не отображаются.Это также программно.

Представление коллекции:

let newCollection: UICollectionView = {
    let layout = UICollectionViewFlowLayout()
    let collection = UICollectionView(frame: CGRect(x: 0, y: 0, width: 0, height: 0), collectionViewLayout: layout)
    layout.scrollDirection = .horizontal
    collection.backgroundColor = UIColor.green
    collection.translatesAutoresizingMaskIntoConstraints = false
    collection.isScrollEnabled = true
    return collection
}()

и настроенные ячейки представления коллекции:

extension WorkerUICollection: UICollectionViewDataSource, UICollectionViewDelegate, UICollectionViewDelegateFlowLayout {

    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
        return worker.count
    }

    func numberOfSectionsInCollectionView(collectionView: UICollectionView) -> Int {
        return 1
    }

    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cellId", for: indexPath) as! CustomeCell
        let cellUsers = worker[indexPath.item]
        cell.textLabel.text! = cellUsers.workerName
        //cell.workerLocation.text! = "2.0 km"
        cell.backgroundColor  = .white
        cell.layer.cornerRadius = 5
        cell.layer.shadowOpacity = 3
        //cell.imageView.image = UIImage(named: "user")
        return cell
    }

    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize {
        return CGSize(width: 150, height: 250)
    }

    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, insetForSectionAt section: Int) -> UIEdgeInsets {
        return UIEdgeInsets(top: 3, left: 3, bottom: 3, right: 3)
    }

}

Функция fetchUser ():

func fetchUser() {
    Database.database().reference().child("Users").observe(DataEventType.childAdded, with: { (snapshot) in
        if let dictionary = snapshot.value as? [String: AnyObject] {
            let worker = WorkerInfo()
            worker.workerName = (dictionary["username"] as! String?)!
            //user.profileImageURL = dictionary["profileImageURL"] as! String?
            DispatchQueue.main.async(execute: {
                self.newCollection.reloadData()
            })
        }
        print(snapshot)
    }, withCancel: nil)
}

Есть идеи?

1 Ответ

0 голосов
/ 23 сентября 2018

потому что ваш self.worker.count = 0. В вашей функции fetchUser() вы должны обновить свой источник данных (рабочий), а не новый из вашей базы данных.Попробуйте что-то вроде этого.

if let array = snapshot.value as? [String: AnyObject] {
   var tempWorkersArray: [WorkerInfo] = []

   for dict in array {
        let worker = WorkerInfo()
        worker.workerName = (dict["username"] as? String) ?? ""
        tempWorkersArray.append(worker)
   }
   self.worker = tempWorkersArray

   DispatchQueue.main.async {
       self.newCollection.reloadData()
   }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...