#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 для номера телефона в виде целого числа, а не строки.