Передача данных Firebase с одного контроллера просмотра на контроллер подробного просмотра

#ios #swift #database #firebase #viewcontroller

#iOS #swift #База данных #firebase #viewcontroller

Вопрос:

Я хочу загрузить данные из моей базы данных Firebase в tableview в моем главном контроллере просмотра, а затем передать эти данные для более подробного описания второму контроллеру просмотра в качестве моего контроллера подробного просмотра. Я застреваю, потому что, когда я нажимаю на ячейку, она не переходит к моему другому контроллеру просмотра, и я не уверен, как передать данные. Я хочу только имя на первом контроллере просмотра, а затем другие данные для заполнения на контроллере подробного просмотра.

Мой основной контроллер просмотра—

 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
        
    }
}
  

и моя ячейка tableview—

 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 использует значения по умолчанию. При подготовке перехода вы помещаете информацию в 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)
        
    }
}
  

Комментарии:

1. Спасибо! Я сделал это, и теперь, когда я перехожу на следующую страницу, на ней не отображаются какие-либо данные?

2. Я обновил ответ, исправив InfoViewController

3. Когда я добавляю их в класс, это выдает мне сообщение об ошибке «Значение типа ‘[FacStaffInfo]’ не имеет элемента ‘title'», но для каждого из них. Но я вижу их в классе FacStaffInfo. могу ли я что-то там упустить?

4. Извините, я не видел, что FacStaffInfo определяется как массив FacStaffData, измените его с var FacStaffData = [FacStaffInfo]() на var FacStaffData = FacStaffInfo! и перейдите к подготовке перехода и измените destinationController.FacStaffData = [table[indexPath.row]] на destinationController.FacStaffData = table[indexPath.row] , я думаю, что это сработает.

5. Итак, когда я вернулся, я изменил var FacStaffData = [FacStaffInfo]() на var FacStaffData : FacStaffInfo? и добавить ? за этим в FacStaffData.Var, и там это сработало. Итак, теперь единственная проблема заключается в загрузке моего Int для номера телефона в виде целого числа, а не строки.