使用Firebase,Xcode 10将2个文本字段传递到自定义Xib单元时出现问题

时间:2018-09-23 21:38:41

标签: ios swift uitableview firebase-realtime-database

我有一个具有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
    }

}

0 个答案:

没有答案