将 Firebase 数据从一个视图控制器传递到详细视图控制器

Posted

技术标签:

【中文标题】将 Firebase 数据从一个视图控制器传递到详细视图控制器【英文标题】:Passing Firebase Data from one view controller to detail view controller 【发布时间】:2020-09-08 20:57:48 【问题描述】:

我希望将 Firebase 数据库中的数据加载到我的主视图控制器中的表视图中,然后将该数据传递给第二个视图控制器作为我的详细视图控制器,以使其更具描述性。我被卡住了,因为当我单击单元格时,它不会连接到我的其他视图控制器,而且我不确定如何让数据通过。我只想要第一个视图控制器上的名称,然后将其他数据填充到详细视图控制器上。

我的主视图控制器--

import UIKit
import Foundation
import Firebase
import FirebaseDatabase

class ViewController: UIViewController 
    
    var table = [FacStaffInfo]()
    var ref: DatabaseReference!

    
    @IBOutlet weak var Tableview: UITableView!

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

        ref = Database.database().reference().child("users")
        
        ref.observe(DataEventType.value, with: (snapshot) in
            if snapshot.childrenCount > 0 
                self.table.removeAll()
                
                for user in snapshot.children.allObjects as! [DataSnapshot] 
                    
                    let object = user.value as? [String: AnyObject]
                    let title = object?["title"]
                    let name = object?["name"]
                    let email = object?["email"]
                    let phone = object?["phone"]
                    let office = object?["office"]
                    let bio = object?["bio"]

                    let user = FacStaffInfo(title: title as! String, name: name as! String, email: email as! String, phone: phone as! Int, office: office as! String, bio: bio as! String)

                    self.table.append(user)
                    
                        self.Tableview.reloadData()
                    
                    
                    
                
            
        )
        
    


extension ViewController: UITableViewDataSource, UITableViewDelegate 
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int 
        return table.count
    
    
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell 
        let cell = tableView.dequeueReusableCell(withIdentifier: "userCell") as! TableViewCell
        
        let user: FacStaffInfo
        
        user = table[indexPath.row]
        cell.titleLabel?.text = user.title
        cell.nameLabel?.text = user.name
        cell.emailLabel?.text = user.email
        cell.phoneLabel?.text = String(user.phone)
        cell.officeLabel?.text = user.office
        cell.bioLabel?.text = user.bio
        
        return cell
    
    
    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) 
            func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) 
            performSegue(withIdentifier: "showDetail", sender: self)
            
    
    
    
    override func prepare(for segue: UIStoryboardSegue, sender: Any?) 
        if segue.identifier == "showDetail" 

            if let indexPath = Tableview.indexPathForSelectedRow 
                let destinationController = segue.destination as! InfoViewController

                destinationController.FacStaffData = [table[indexPath.row]]
            
        
    

我的详细视图控制器--

import UIKit
import Firebase
import FirebaseDatabase

class InfoViewController: UIViewController 
    
var FacStaffData = [FacStaffInfo]()
    
    @IBOutlet weak var titleLabel: UILabel!
    @IBOutlet weak var nameLabel: UILabel!
    @IBOutlet weak var emailLabel: UILabel!
    @IBOutlet weak var phoneLabel: UILabel!
    @IBOutlet weak var officeLabel: UILabel!
    @IBOutlet weak var bioLabel: UILabel!
    
    //var title = ""
    var name = ""
    var email = ""
    var phone = ""
    var office = ""
    var bio = ""
    
    override func viewDidLoad() 
        super.viewDidLoad()

        titleLabel.text = title
        nameLabel.text = name
        emailLabel.text = email
        phoneLabel.text = phone
        officeLabel.text = office
        bioLabel.text = bio
        
        print(titleLabel)
        
    

我的信息类--

import Foundation
import Firebase
import FirebaseDatabase


class FacStaffInfo 
    
    var title: String
    var name: String
    var email: String
    var phone: Int
    var office: String
    var bio: String
    
    init(title: String, name: String, email: String, phone: Int, office: String, bio: String) 
        self.title = title;
        self.name = name;
        self.email = email;
        self.phone = phone;
        self.office = office;
        self.bio = bio
        
    

还有我的表格视图单元格--

import UIKit
import Firebase
import FirebaseDatabase

class TableViewCell: UITableViewCell 
  
    @IBOutlet weak var titleLabel: UILabel!
    @IBOutlet weak var nameLabel: UILabel!
    @IBOutlet weak var emailLabel: UILabel!
    @IBOutlet weak var phoneLabel: UILabel!
    @IBOutlet weak var officeLabel: UILabel!
    @IBOutlet weak var bioLabel: UILabel!
    
    override func awakeFromNib() 
        super.awakeFromNib()
        // Initialization code
    

    override func setSelected(_ selected: Bool, animated: Bool) 
        super.setSelected(selected, animated: animated)

        // Configure the view for the selected state
    

【问题讨论】:

【参考方案1】:

看起来 didSelectRowAt 只是再次实现了 didSelectRowAt 而没有调用任何东西。

func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) 
            func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) 
            performSegue(withIdentifier: "showDetail", sender: self)
            
    

再试一次:

func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) 
                performSegue(withIdentifier: "showDetail", sender: self)
                

后续更新:

InfoViewController 使用默认值。准备 segue 时,将信息放入 FacStaffData。这应该可以解决问题。

    class InfoViewController: UIViewController 
    
var FacStaffData = [FacStaffInfo]()
    
    @IBOutlet weak var titleLabel: UILabel!
    @IBOutlet weak var nameLabel: UILabel!
    @IBOutlet weak var emailLabel: UILabel!
    @IBOutlet weak var phoneLabel: UILabel!
    @IBOutlet weak var officeLabel: UILabel!
    @IBOutlet weak var bioLabel: UILabel!
    
    override func viewDidLoad() 
        super.viewDidLoad()

        titleLabel.text = FacStaffData.title
        nameLabel.text = FacStaffData.name
        emailLabel.text = FacStaffData.email
        phoneLabel.text = FacStaffData.phone
        officeLabel.text = FacStaffData.office
        bioLabel.text = FacStaffData.bio
        
        print(titleLabel)
        
    

【讨论】:

谢谢!我这样做了,现在当我转到下一页时,它没有显示任何数据? 我更新了答案,更正了 InfoViewController 当我将这些添加到类中时,它给我一个错误,提示“'[FacStaffInfo]' 类型的值没有成员'title'”,但对于每一个。但我在 FacStaffInfo 类中看到了它们。我会在里面遗漏什么吗? 对不起,我没有看到 FacStaffInfo 被定义为 FacStaffData 的数组 将其从 var FacStaffData = [FacStaffInfo]() 更改为 var FacStaffData = FacStaffInfo! 并准备 segue 并将 destinationController.FacStaffData = [table[indexPath.row]] 更改为 destinationController.FacStaffData = table[indexPath.row] 我认为会做的。 所以当我回去时,我将 var FacStaffData = [FacStaffInfo]() 更改为 var FacStaffData : FacStaffInfo?并添加一个?在 FacStaffData.Var 的后面,它在那里工作。所以现在唯一的问题是将电话号码的 Int 作为整数而不是字符串加载。

以上是关于将 Firebase 数据从一个视图控制器传递到详细视图控制器的主要内容,如果未能解决你的问题,请参考以下文章

Swift 3 数据从主控制器到带有 Firebase 和 segue 的视图控制器

使用 AVAudioPlayer 将 URL 从 tableview 控制器传递到视图控制器

Swift:如何将数据从 TableViewController 传递到 Details VC

将图像从集合视图控制器快速传递到另一个视图控制器

扑动 Firebase 动画列表视图如何将数据传递到详细信息屏幕

firebase 在 Swift 中关闭重载表?