我正在尝试将Firebase数据库中的数据导入我的UITableViewController
。
UITableViewController
的含义是显示谁喜欢您正在访问的帖子。
当有人喜欢发帖时,他们的userID
会被放置在likesForPost
类别的帖子中 - 正如您在此处所见:
如您所见,1人已经喜欢这篇文章(黑匣子是userID
)。
问题是我的单元格上没有显示任何数据。我试图在我的手机上显示userID
,但没有任何显示。然而,我确实得到的单元格数量等于喜欢该帖子的人数。
我应该解释viaSegue
从prepareForSegue
获取密钥,是的,它显示的是正确的密钥,所以这不是问题: - )
这是我的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]
}
}
答案 0 :(得分:0)
它应该像调用
一样简单self.updates = newUpdates
self.tableView.reloadData()
在主队列上。您无法在非主线程上更新UI。
尝试并执行此操作
DispatchQueue.main.async {
self.updates = newUpdates
self.tableView.reloadData()
}