从另一个TableView添加行 - Swift

时间:2018-04-14 20:18:20

标签: swift string tableview segue protocols

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

        }
    }

}

1 个答案:

答案 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)
}