Это мое первое приложение для iOS.
Итак, у меня есть UIVIewController
с UITableView
, где я интегрировал UISearchBar
и UISearchController
, чтобы отфильтровать TableCells для отображения
override func viewDidLoad() {
menuBar.delegate = self
table.dataSource = self
table.delegate = self
let nib = UINib(nibName: "ItemCellTableViewCell", bundle: nil)
table.registerNib(nib, forCellReuseIdentifier: "Cell")
let searchButton = UIBarButtonItem(barButtonSystemItem: .Search, target: self, action: "search:")
menuBar.topItem?.leftBarButtonItem = searchButton
self.resultSearchController = ({
let controller = UISearchController(searchResultsController: nil)
controller.searchResultsUpdater = self
controller.dimsBackgroundDuringPresentation = false
return controller
})()
self.table.reloadData()
}
Я также использую модальный переход, чтобы открыть ViewController
элемента, где я покажу детали элемента.
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
self.index = indexPath.row
self.performSegueWithIdentifier("ItemDetailFromHome", sender: self)
}
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
if (segue.identifier == "ItemDetailFromHome") {
let settingsVC = segue.destinationViewController as! ItemDetailViewController
settingsVC.parent = self
if self.isSearching == true && self.searchText != nil && self.searchText != "" {
settingsVC.item = self.filteredItems[self.index!]
} else {
settingsVC.item = self.items[self.index!]
}
}
}
Это работает нормально, пока я не попытаюсь отобразить ItemDetailViewController
для фильтруемого элемента (через UISearchController
).
У меня такое сообщение:
Warning: Attempt to present <ItemDetailViewController: *> on <HomeViewController: *> which is already presenting (null)
Каждый раз я перехожу к функции ItemDetailViewController.viewDidLoad()
, но после этого, когда поиск активирован, у меня появляется предыдущая ошибка.
Любая идея ? Я попытался использовать следующую асинхронную отправку, но безуспешно
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
self.index = indexPath.row
dispatch_async(dispatch_get_main_queue(), { () -> Void in
self.performSegueWithIdentifier("ItemDetailFromHome", sender: self)
})
}
ItemDetailViewController
будет представлением, используемым несколькими segue / viewController (объединенными). - person Splendf   schedule 21.09.2015