我想实现UISearchController,使用本教程一步一步地进行:
Search for places using MKLocalSearchRequest and display results with UISearchController
在本节中......
Search for locations using MKLocalSearchRequest
...我遇到了第3步的问题。设置表视图数据源
extension LocationSearchTable {
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return matchingItems.count
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("cell")!
let selectedItem = matchingItems[indexPath.row].placemark
cell.textLabel?.text = selectedItem.name
cell.detailTextLabel?.text = ""
return cell
}
}
我试图从override
tableView函数中删除cellForRowAtindexPath
,在这种情况下,我在Xcode中没有错误,但在执行后出错:
Terminating app due to uncaught exception 'NSInternalInconsistencyException',
reason: 'UITableView (<UITableView: 0x7ff8e03a3800; frame = (0 0; 375 667); clipsToBounds = YES; autoresize = W+H;
gestureRecognizers = <NSArray: 0x604002046450>; layer = <CALayer: 0x604001626620>;
contentOffset: {0, -56}; contentSize: {375, 132};adjustedContentInset: {56, 0, 0, 0}>)
failed to obtain a cell from its dataSource(<CityWeather.LocationSearchTable: 0x7ff8de696e60>)'
错误消息大喊:failed to obtain a cell from its dataSource(<CityWeather.LocationSearchTable: 0x7ff8de696e60>)
请告诉我,我做错了什么?我怎么能处理这个问题?感谢。
答案 0 :(得分:8)
tutorial使用UITableviewDatasource方法的旧语法(可能是Swift 2.2):
你现在需要这些:
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
}
始终尽可能使用XCode的代码完成。
答案 1 :(得分:2)
正如Puneet Sharma所说,你不需要覆盖方法。因为您在UITableViewDatasource
中使用UITableViewDelegate
(和UIViewController
)。
您需要在tableView
。{/ p>中设置ViewController
的代理人