按下UITableView行时是否正确触发视图控制器打开?

时间:2019-06-25 14:33:29

标签: ios swift uitableview uitableviewrowaction

当按下UITableView行时,如何正确触发视图控制器打开?

我需要允许用户从视图控制器返回到tableView,并允许他们选择相同或不同的tableView行。

我当前遇到的问题是,从同一行中选择时打开的ViewController返回返回后,多次选择同一行时,应用程序崩溃:scheduledDelivery

当前,这是我拥有的代码:

import UIKit

class ScheduledCell: UITableViewCell {

    @IBOutlet weak var ETALabel: UILabel!
    @IBOutlet weak var cellStructure: UIView!

    @IBOutlet weak var scheduledLabel: UILabel!
    @IBOutlet weak var testingCell: UILabel!
    @IBOutlet weak var pickupLabel: UILabel!
    @IBOutlet weak var deliveryLabel: UILabel!
    @IBOutlet weak var stopLabel: UILabel!
    @IBOutlet weak var topBar: UIView!


}

class ToCustomerTableViewController: UITableViewController, UIGestureRecognizerDelegate {

    var typeValue = String()

    var driverName = UserDefaults.standard.string(forKey: "name")!
    var structure = [AlreadyScheduledStructure]()


    override func viewDidLoad() {
        super.viewDidLoad()

        fetchJSON()


        //Disable delay in button tap
        self.tableView.delaysContentTouches = false

        tableView.tableFooterView = UIView()

    }


    private func fetchJSON() {
        guard let url = URL(string: "https://example.com/example/example"),
            let value = driverName.addingPercentEncoding(withAllowedCharacters: .urlQueryValueAllowed)
            else { return }

        var request = URLRequest(url: url)
        request.httpMethod = "POST"
        request.httpBody = "driverName=\(value)".data(using: .utf8)

        URLSession.shared.dataTask(with: request) { data, _, error in
            guard let data = data else { return }


            do {
                self.structure = try JSONDecoder().decode([AlreadyScheduledStructure].self,from:data)
                DispatchQueue.main.async {
                    self.tableView.reloadData()
                }
            }
            catch {
                print(error)
            }

            }.resume()

    }



    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        return structure.count
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        let cell = tableView.dequeueReusableCell(withIdentifier: "scheduledID", for: indexPath) as! ScheduledCell
        let portfolio = structure[indexPath.row]
        cell.stopLabel.text = "Stop \(portfolio.stop_sequence)"
        return cell

    }

    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {


        let portfolio = structure[indexPath.row]
        let controller = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "scheduledDelivery")

        print(portfolio.customer)
        let navTitle = portfolio.customer
        UserDefaults.standard.set(navTitle, forKey: "pressedScheduled")
        controller.navigationItem.title = navTitle
        navigationController?.pushViewController(controller, animated: true)
    }


    override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
        return 200.0
    }

}

请注意,我如何在cellForRowAt中将单元格设置为dequeueReusableCell,这可能就是为什么当多次选择同一单元格时应用有时崩溃的原因

let cell = tableView.dequeueReusableCell(withIdentifier: "scheduledID"

我还注意到,如果将tableView行重新加载到viewDidAppear上,它不会经常崩溃,但这当然是一个糟糕的解决方案。

我得到的错误:

  

“ NSInternalInconsistencyException”,原因:“试图出队   同一索引路径的多个单元格,这是不允许的。如果你   确实需要比表格视图请求的更多单元出队,   使用-dequeueReusableCellWithIdentifier:方法

1 个答案:

答案 0 :(得分:0)

根据崩溃替换

let cell = tableView.dequeueReusableCell(withIdentifier: "scheduledID", for: indexPath) as! ScheduledCell

使用

let cell = tableView.dequeueReusableCell(withIdentifier: "scheduledID") as! ScheduledCell