从firebase获取数据到UITableViewController - swift

时间:2016-10-27 14:33:26

标签: ios swift uitableview firebase firebase-realtime-database

我正在尝试将Firebase数据库中的数据导入我的UITableViewController

UITableViewController的含义是显示谁喜欢您正在访问的帖子。

当有人喜欢发帖时,他们的userID会被放置在likesForPost类别的帖子中 - 正如您在此处所见:

enter image description here

如您所见,1人已经喜欢这篇文章(黑匣子是userID)。

问题是我的单元格上没有显示任何数据。我试图在我的手机上显示userID,但没有任何显示。然而,我确实得到的单元格数量等于喜欢该帖子的人数。

我应该解释viaSegueprepareForSegue获取密钥,是的,它显示的是正确的密钥,所以这不是问题: - )

这是我的UITableViewController

import UIKit
import FirebaseDatabase
import FirebaseAuth
import FBSDKCoreKit
import FirebaseStorage

class viewLikesTableViewController: UITableViewController {
    var viaSegue = "Nothing"
    var updates = [LikeSweet]()

    override func viewDidLoad() {
        super.viewDidLoad()

        let logo = UIImage(named: "logo.png")
        let imageView = UIImageView(image:logo)
        self.navigationItem.titleView = imageView

        print(viaSegue)

        startObersvingDB()
    }

    func startObersvingDB() {
            FIRDatabase.database().reference().child("feed-items").child(self.viaSegue).child("likesForPost").observeEventType(.Value, withBlock: { (snapshot: FIRDataSnapshot) in
                    // Get user value
                var newUpdates = [LikeSweet]()

                for update in snapshot.children {
                    let updateObject = LikeSweet(snapshot: update as! FIRDataSnapshot)
                    newUpdates.append(updateObject)

                }

                self.updates = newUpdates
                self.tableView.reloadData()
            }) { (error: NSError) in
                print(error.description)
            }
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
        return 1
    }

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return updates.count
    }

    override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
        tableView.deselectRowAtIndexPath(indexPath, animated: true)

        let update = updates[indexPath.row]

        let allDataSend = update.userID
        self.performSegueWithIdentifier("showProfile", sender: allDataSend)
    }

    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell:viewLikesTableViewCell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! viewLikesTableViewCell

            let update = updates[indexPath.row]

            cell.nameLabel.text = update.userID
        return cell
    }
}

您可能还需要LikeSweet代码:

import Foundation
import FirebaseDatabase
import FirebaseAuth
import UIKit

struct LikeSweet {
    let key: String!
    let userID: String!
    let itemRef: FIRDatabaseReference?
    let path : String!

    init (userID: String, key: String = "") {
        self.key = key
        self.userID = userID
        self.itemRef = nil
        // self.path = dataPath
        self.path = ""
    }

    init (snapshot: FIRDataSnapshot) {
        key = snapshot.key
        itemRef = snapshot.ref
        path  = key
        if let theFeedContent = snapshot.value!["userID"] as? String {
            userID = theFeedContent
        } else {
            userID = ""
        }
    }

    func toAnyObject() -> AnyObject {
        return ["userID":userID]
    }
}

1 个答案:

答案 0 :(得分:0)

它应该像调用

一样简单
self.updates = newUpdates
self.tableView.reloadData()

在主队列上。您无法在非主线程上更新UI。

尝试并执行此操作

DispatchQueue.main.async {
  self.updates = newUpdates
  self.tableView.reloadData()
}