在表格视图中显示Firebase数据

时间:2020-08-14 14:15:42

标签: swift xcode firebase tableview

我正在尝试检索存储在Firebase数据库中的信息,但是我的表视图未显示该信息。我尝试使用打印功能来查看是否正在检索数据,这表明确实是这种情况,但是当我运行模拟器时,tableview显示为空白。

我正在使用Xcode 11,并且由于某些原因,我看过的每个教程都无法正常工作。

这是我的代码:


import UIKit
import Firebase
import FirebaseDatabase
import SwiftKeychainWrapper
import FirebaseAuth

class FeedVC: UITableViewController {
    
    var currentUserImageUrl: String!
    var posts = [postStruct]()
    var selectedPost: Post!

    override func viewDidLoad() {
        super.viewDidLoad()
        getUsersData()
        getPosts()
        // Do any additional setup after loading the view.
        
    }

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

        guard let userID = Auth.auth().currentUser?.uid else { return }
        Database.database().reference().child("users").child(userID).observeSingleEvent(of: .value) { (snapshot) in
            if let postDict = snapshot.value as? [String : AnyObject] {
                self.tableView.reloadData()
            }
        }
    }
    
    struct postStruct {
        let firstName : String!
        let lastName : String!
    }
    
    func getPosts() {
        let databaseRef = Database.database().reference()
        databaseRef.child("profiles").queryOrderedByKey().observeSingleEvent(of: .childAdded, with: {
                    snapshot in
                    let firstName = (snapshot.value as? NSDictionary)!["profileForename"] as? String
                    let lastName = (snapshot.value as? NSDictionary
                        )!["profileSurname"] as? String
                    print(firstName)
                    self.posts.append(postStruct(firstName: firstName, lastName: lastName))
                    print(self.posts)
                    DispatchQueue.main.async {
                        self.tableView.reloadData()
                    }
                })
    }
    
    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    
    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return posts.count
    }
    
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        
        guard let cell = tableView.dequeueReusableCell(withIdentifier: "PostCell") as? PostCell else { return UITableViewCell() }
        
        let nameLabel = cell.viewWithTag(1) as! UILabel
        nameLabel.text = posts[indexPath.row].firstName
        return cell
    }



}

任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:1)

更新:由于PostCell是在表视图内的情节提要中创建的,因此已成功注册和出队。因此,问题被缩小到带有标签1的标签。尝试为标签创建@IBOutlet,并使用它来设置UILabel的文本。

screenshot

然后在cellForRowAt中输入

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    guard let cell = tableView.dequeueReusableCell(withIdentifier: "PostCell") as? PostCell else { return UITableViewCell() }
    cell.firstNameLabel.text = posts[indexPath.row].firstName
    return cell
}

上一个:您似乎忘记了registerPostCell

override func viewDidLoad() {
    super.viewDidLoad()
    //...
    tableView.register(PostCell.self, forCellReuseIdentifier: "PostCell")
}

注意:如果您在Xib中创建了PostCell,请使用nib注册表方法。

更新:如果要使用Nib方法注册,请使用:

tableView.register(UINib(nibName: <#T##String#>, bundle: nil), forCellReuseIdentifier: "PostCell") // provide the xib file name at the placeholder