我正在尝试这样做,以便当我在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)
}

09-25 18:53