我正在尝试这样做,以便当我在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
}
}
}
答案 0 :(得分:0)
您需要弄清楚用户点击的列表项的索引。目前您只是传递整个列表。这条线需要调整:
在:
@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)
}