我有一个具有2个文本字段(膳食标题和描述)的视图控制器,该信息将该信息传递给另一个具有表视图的视图控制器(使用Xcode 10和firebase)。我还有一个使用xib文件在tableview中设计的自定义单元格。自定义单元格具有标题及其下的描述。 (我最终还将在单元格中拥有一张图片,但尚未设置好图片,因此请在代码中忽略它)。
问题在于,表格视图中的单元格在同一单元格中未显示餐食标题及其下的描述。它在第一行中显示为标题键入的内容,作为标题和描述,在第二行中显示为标题键入的内容。例如,我在进餐标题中输入了“ Chicken Parm”,在描述中输入了“ Chicken,mozzarella,sauce,spaghetti”,但是模拟器表视图显示了第一个标题为“ Chicken Parm”且描述为“ Chicken Parm”的单元格。 ”。表格视图的第二行显示标题为“鸡肉,芝士,调味酱,意大利面”,描述也为“鸡肉,芝士,调味酱,意大利面”。
我还没有找到任何从另一个视图控制器传递数据的示例,它们都只是使用一个传递给tableview的数组。任何帮助将不胜感激!
我的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)
}
}
我设置了tableview的视图控制器如下:
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
}
}