Передача данных из ячейки прототипа с помощью кнопки внутри ячейки таблицы - PullRequest
0 голосов
/ 19 января 2019

У меня есть данные, которые динамически заполняют ячейки прототипа.Это создаст только столько ячеек данных, сколько требуется.У меня возникла проблема с передачей данных в подробный вид при нажатии кнопки UIB.

Внутри каждой динамической ячейки есть кнопка UIB, которая при нажатии передает все данные, находящиеся внутри ячейки, выбранной в детали.view.

У меня нет проблем с загрузкой данных в табличное представление, я просто не могу правильно передать значения.

Вот моя ячейка для строки:

override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "part", for: indexPath) as! partsTableCell

    let part = partList[0]

    cell.a.text = String(part.a)
    cell.b.text = part.b
    cell.c.text = part.c
    cell.d.text = part.d
    cell.e.text = part.e
    cell.f.text = part.f

    self.tableView.rowHeight = 250
    cell.layer.borderColor = UIColor.darkGray.cgColor
    cell.layer.borderWidth = 1
    cell.layer.cornerRadius = 5
    cell.clipsToBounds = true
  //tried using tags, but no luck
    //cell.myButton.tag = indexPath.row

    return cell
}

Ради тщательности я настроил пользовательский класс для ячейки таблицы.

class partsTableCell: UITableViewCell {
    @IBOutlet weak var a: UILabel!
    @IBOutlet weak var b: UILabel!
    @IBOutlet weak var c: UILabel!
    @IBOutlet weak var d: UILabel!
    @IBOutlet weak var e: UILabel!
    @IBOutlet weak var f: UILabel!
    @IBOutlet weak var myButton: UIButton!
}

И вот где я передаю данные:

    func prepare(for segue: UIStoryboardSegue, sender: UIButton) {


        if (segue.identifier == "partDetail") {
            let detailVC = segue.destination as? PartsVCDetail
            let indexPath = self.tableView.indexPathForSelectedRow
            let part = dataList[indexPath.row]
            detailVC?.a = part.a!
            detailVC?.b = part.b!
            detailVC?.c = part.c!
            detailVC?.d = part.d!
            detailVC?.e = part.e!
            detailVC?.f = part.f

        }
}

Все соответствуетхорошо, но когда я нажимаю кнопку, и происходит переход.Данные выходят пустыми или нулевыми на другой стороне.

Я что-то упускаю из виду?

Любая помощь будет отличной!

Спасибо

РЕДАКТИРОВАТЬ -

Вот как я настроил свою деталь VC

@IBOutlet weak var qq: UILabel!
@IBOutlet weak var ww: UILabel!
@IBOutlet weak var ee: UILabel!
@IBOutlet weak var rr: UILabel!
@IBOutlet weak var tt: UILabel!
@IBOutlet weak var yy: UILabel!
@IBOutlet weak var uu: UILabel!

var a: Int64!
var b: String = ""
var c: String = ""
var d: String = ""
var e: String = ""
var f: String = ""
var g: String = ""


override func viewDidLoad() {
    super.viewDidLoad()
    //lineNumber.text = "test"

    print(a,"************")
    print(b, "************")
    print(c, "************")
    print(d, "************")
    print(e, "************")
    print(f,"************")
//ALL DATA ABOVE IS EITHER NULL OR EMPTY

    qq.text = a as! String
    ww.text = b
    ee.text = c
    rr.text = d
    tt.text = e
    yy.text = f
    uu.text = g

}

1 Ответ

0 голосов
/ 19 января 2019
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "part", for: indexPath) as! partsTableCell

let part = partList[0]

cell.a.text = String(part.a)
cell.b.text = part.b
cell.c.text = part.c
cell.d.text = part.d
cell.e.text = part.e
cell.f.text = part.f

self.tableView.rowHeight = 250
cell.layer.borderColor = UIColor.darkGray.cgColor
cell.layer.borderWidth = 1
cell.layer.cornerRadius = 5
cell.clipsToBounds = true

// give tag to your button and add target
cell.myButton.tag = indexPath.row
cell.myButton.addTarget(self, action: #selector(myButtonAction), for: .touchUpInside)

return cell

}

@objc func myButtonAction(sender:UIButton)  {
// in button action do your stuff like below

let part = partList[sender.tag]

let detailVC = UIStoryboard(name: "YourStoryBoard", bundle: nil).instantiateViewController(withIdentifier: "partDetail") as! PartsVCDetail
detailVC?.a = part.a!
detailVC?.b = part.b!
detailVC?.c = part.c!
detailVC?.d = part.d!
detailVC?.e = part.e!
detailVC?.f = part.f
self.navigationController?.pushViewController(detailVC, animated: true)

}

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