Проблемы с передачей 2 текстовых полей в пользовательскую ячейку xib с помощью Firebase, Xcode 10 - PullRequest
0 голосов
/ 24 сентября 2018

У меня есть контроллер представления с 2 текстовыми полями (заголовок и описание еды), который передает эту информацию второму контроллеру представления, который имеет табличное представление (используя Xcode 10 и firebase).У меня также есть пользовательская ячейка, созданная в табличном представлении с использованием файла XIB.Пользовательская ячейка имеет заголовок с описанием под ним.(Со временем у меня будет изображение в ячейке, но я его не настрою, поэтому, пожалуйста, проигнорируйте его в коде).

Проблема в том, что ячейка в табличном представлении не показывает название еды с описанием под ней в той же ячейке.Он отображает то, что я напечатал для заголовка в качестве заголовка и описания в первой строке, и то, что я напечатал в качестве описания в заголовке и описания во второй строке.Например, я ввел «Chicken Parm» в названии еды и «Курица, моцарелла, соус, спагетти» в описании, но в табличном представлении симулятора отображается первая ячейка с названием «Chicken Parm» и описанием как «Chicken Parm».«.Вторая строка в табличном виде показывает заголовок как «Курица, моцарелла, соус, спагетти» и описание как «Курица, моцарелла, соус, спагетти».

Я не нашел ни одного примера, передающего данныеиз другого контроллера представления все они просто используют массив, который они передают в табличное представление.Любая помощь приветствуется!

Мой файл xib выглядит следующим образом:

import UIKit

class TableViewCell: UITableViewCell {

    @IBOutlet weak var mealImage: UIImageView!
    @IBOutlet weak var mealTitle: UILabel!
    @IBOutlet weak var mealDesc: UILabel!

    override func awakeFromNib() {
        super.awakeFromNib()

    }

    func commonInit(_ imageName: String, title: String, desc: String) {
        mealImage.image = UIImage(named: imageName)
        mealTitle.text = title
        mealDesc.text = desc
    }

}

Мой контроллер представления с текстовыми полями выглядит следующим образом:

import UIKit
import FirebaseDatabase

var handle: DatabaseHandle?
var ref: DatabaseReference!

class ViewController4: UIViewController {

    @IBOutlet weak var myTextField: UITextField!
    @IBOutlet weak var IngredientsTextField: UITextField!

    @IBAction func saveButton(_ sender: Any) {

        //To save an item to the database

        if myTextField.text != "" && IngredientsTextField.text != "" {
            ref?.child("list").childByAutoId().setValue(myTextField.text)
            ref?.child("list").childByAutoId().setValue(IngredientsTextField.text)

            //To delete words out after hitting save
            myTextField.text = ""
            IngredientsTextField.text = ""
        }
    }

    override func viewDidLoad() {
        super.viewDidLoad()

        ref = Database.database().reference()

        handle = ref?.child("list").observe(.childAdded, with: { (snapshot) in

            if let item = snapshot.value as? String {
                myList.append(item)
            }
        })

    }

    // Hide Keyboard when touch outside keyboard
    override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
        self.view.endEditing(true)
    }

}

Мой видКонтроллер с установленной таблицей выглядит следующим образом:

import UIKit
import FirebaseDatabase

var myList: [String] = []

class ViewController3: UIViewController, UITableViewDelegate, UITableViewDataSource {

    @IBOutlet weak var myTableView: UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()

        self.title = "UITableView"

        //Register custom cell to the tableview
        let nibName = UINib(nibName: "TableViewCell", bundle: nil)
        myTableView.register(nibName, forCellReuseIdentifier: "tableViewCell")
    }

    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return myList.count
    }

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

        let cell = tableView.dequeueReusableCell(withIdentifier: "tableViewCell", for: indexPath) as! TableViewCell

        cell.commonInit("got_\(indexPath.item)", title: myList[indexPath.item], desc: myList[indexPath.item])

        return cell
    }

}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...