У меня есть контроллер представления с 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
}
}