Как правильно запустить контроллер представления, чтобы открыть, когда нажата строка 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: метод