我正在尝试这样做,以便当我在listtableviewcontroller上单击数组的一项时,它将将此选择传递给dataaddedtableviewcontroller并追加选择,以便我可以继续添加到列表中。 Storyboard
我尝试使用协议和委托传递数据,但是传递的只是整个列表本身(我认为这主要是因为我使用按钮而不是单击单元格,因为我不知道如何做)。我也尝试使用segues传递数据,但是单击单元格后似乎无法追加数据。
任何帮助将不胜感激。非常感谢!
FirstViewController:
protocol ListTableViewControllerDelegate {
func addNew(todo: String)
}
class ListTableViewController: UITableViewController {
var delegate: ListTableViewControllerDelegate?
var list = ["chicken", "phone", "water"]
@IBAction func saveToList(_ sender: Any) {
delegate?.addNew(todo: "\(list)")
navigationController?.popToRootViewController(animated: true)
}
override func viewDidLoad() {
super.viewDidLoad()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
// #warning Incomplete implementation, return the number of rows
return list.count
}
}
SecondViewController:
class DataAddedTableViewController: UITableViewController, ListTableViewControllerDelegate {
var dataAdded = [String]()
func addNew(todo: String) {
dataAdded.append(todo)
tableView.reloadData()
}
override func viewDidLoad() {
super.viewDidLoad()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
// #warning Incomplete implementation, return the number of rows
return dataAdded.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)
cell.textLabel?.text = dataAdded[indexPath.row]
return cell
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if let destVC = segue.destination as? ListTableViewController {
destVC.delegate = self as ListTableViewControllerDelegate
}
}
}
最佳答案
您需要找出用户点击的列表项的索引。目前,您只是通过整个列表。此行需要调整:
之前:
@IBAction func saveToList(_ sender: Any) {
delegate?.addNew(todo: list)
navigationController?.popToRootViewController(animated: true)
}
后:
@IBAction func saveToList(_ sender: Any) {
let index = CODE_NEEDE_HERE //figure out how to find out the index of the list
delegate?.addNew(todo: list[index])
navigationController?.popToRootViewController(animated: true)
}
我想您有一个不使用委托方法tableView(_:didSelectRowAt:)的正当理由吗?
使用
tableView(_:didSelectRowAt:)
解决方案可能是这样的:override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
let item = list[indexPath.row]
delegate?.addNew(todo: item)
}