关于这个问题有很多问题,但到目前为止我找到的答案并不适用。在这种情况下,该表在 iOS 9.3.5 中正常工作,但不适用于 iOS 10(或 10.3.1)
我已经排除了:
- 没有正确设置委托。代表执行 3 个功能,
didSelectRowAt
, heightForRowAt
, and editActionsForRowAt
. 后者是从右向左滑动,它提供了执行与选择行完全相同的功能的选项。。这三个函数在 v9.3.5 上可以正常工作(通过模拟器和我测试的旧版 iPad 进行测试)。当我通过模拟器或 iPhone SE 使用 v10 时,heightForRowAt
, and editActionsForRowAt
工作但不是didSelectRowAt
(就此而言 - 我尝试过willSelectRowAt
。它也不适用于 v10。)
- 任何印刷错误(因为它适用于 9.3.5)
我还没有找到任何有关 Swift 更改的信息tableView(:didSelectRowAt)
从 iOS 9 到 iOS 10。
背景
我有一个带有相应 xib (“DetailVC”)的视图控制器。该 xib 有一个标签,然后标签下方有一个表格视图。该表的单元格是另一个 xib。
视图控制器通过以下方式呈现
let uomVC = DetailVC()
self.navigationController?.pushViewController(uomVC, animated: true)
然后在 DetailVC 中,我使用 NSFetchedDataController 并通过 tableView 数据源委托将其连接到 tableview。 (核心数据加载和显示效果很好。)
Code(我将根据需要/要求发布额外的代码 - Swift 3)
viewDidLoad() - 部分
let nib: String = "DetailCell"
let reuseID: String = "detailCell"
tableView.register(UINib.init(nibName: nib, bundle: nil), forCellReuseIdentifier: reuseID)
表视图(:cellForRowAt)
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: reuseID) as! IngredientDetailCell
cell.present(ingredient: _fetchedResultsController.object(at: indexPath))
cell.isUserInteractionEnabled = true // Added later as a guess per SO suggestions
return cell
}
为了争论 - 这不会打印
func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
print("Selected a row")
// delegate?.selectedIngredient(_fetchedResultsController.object(at: indexPath))
// self.navigationController?.popViewController(animated: true)
}
View