我有一个问题与UITableView的didSelectRowAtIndexPath。

我的表已经设置好了,所以当我选择row时,它会初始化一个新的视图控制器并推送它。

当我第一次点击表中的任何一行时,该方法不会被调用。一旦我选择了另一行,它就开始正常工作。

我已经通过在didSelectRowAtIndexPath上设置断点验证了这一点。当添加一个NSLog的方法,我看到,当我选择第二行,最后推动新的视图控制器,我看到两个日志语句出现在控制台同时。

有什么建议吗?


你有没有不小心输入了didDeselectRowAtIndexPath?


也检查xib文件中表视图的选择属性。按需要使用“单选”或“多选”。


我甚至对张贴这个答案进行了辩论,因为我认为为了证明这一点,星星有点对准了。

我有这个问题的变化,并检查了其他解决方案。在我的表视图中,它不是在第一次点击时处理表的最后一行。它突出显示它,但是didSelectRowAtIndexPath没有被调用。其他行都没问题。但如果我打开tableviewbounce,问题似乎就解决了(但你必须处理tableviewbounce)


我遇到了以下问题:

第一次点击行->没有效果,没有选择,从来没有 第二次点击和下面->正确的选择行为,总是

在我的情况下,我的错误是在界面生成器的触摸上检查显示选择。你可以在IB中取消勾选:

希望这能帮助到别人


检查是否在类中设置了任何手势识别器。移动手势对我有用。


斯威夫特2

确保你把这个设置为true:

self.tableView.allowsSelection = true

把它放在右边的viewDidLoad()之后,super.viewDidLoad()之前


UITableViewCellSelectionStyleNone被设置为显示该问题的单元格 (ios9)。

我最后还是打了个电话

[tableView deselectRowAtIndexPath:indexPath animated:NO];

首先

- (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath

这是不一样的,但已经足够好了。 这让我很好奇ios10会带来怎样的表格破坏。


斯威夫特3

如果你在一个不是UITableViewController的类中使用Swift 3,并且你正在使用UITableViewDelegate,那么你可能需要使用方法title:

@objc(tableView:didSelectRowAtIndexPath:) func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath){...}

这对我来说很有效,尽管我刚刚将我的项目迁移到Swift 3。这是一个相当新的问题,所以稍后可能会修复。


didSelectRowAt函数没有被调用在我的应用程序在第一次或第二次点击… 我试图解决这个问题却找不到任何解决方法。但突然间我意识到,我用的是视图。动画颜色变化…动画持续时未调用委托方法


斯威夫特3

其他的答案都不适合我,让我解决问题的是:

tableView.delaysContentTouches = false


如果你在你的类中设置了任何UITapGestureRecognizer,你可以在你的didSelectRowAtIndexPath中添加这一行:

[tableView deselectRowAtIndexPath:indexPath animated:NO];

这对我很管用。


当你在tableView中使用手势识别器时,这个问题也会发生,在这种情况下,你不需要删除它们,你只需要确保你的手势属性cancelsTouchesInView = false,这是一个布尔值,影响当手势被识别时触摸是否被传递到视图。


在我的例子中,我有一个带有手势识别器的UITableView节头。当点击标题时,它应该在该部分中插入几行,并使插入动画化(如展开/折叠部分)。 第一次展开和点击时,didSelectRow委托方法没有被触发。对于进一步的开采和扩展/收缩操作,它的工作情况与预期一致。

根据@Ayoub Nouri的回答,我将cancelsTouchesInView设置为false,这解决了问题。 tapGestureRecognizer ?。cancelsTouchesInView = false


斯威夫特4.2

在属性检查器中禁用“延迟触摸”解决了这个问题。 之后,点击是流畅的和didSelectRowAt立即启动。


对我来说有用的是开始输入“didSelect…”,然后让自动更正填充剩下的部分。显然我的一些语法细节是不可靠的。正如其他人所说,使用IDE!!


我在我的tableView(swift 4.2)上也有同样的问题,它可以用tableView上的allowmultipleselection属性来修复。

如果allowsMultipleSelection设置为true,表视图的选择机制将改变,通过选择每个单元格tableView didSelectRowAtIndexPath:第一次被调用,通过选择相同的单元格第二次tableView didDeselectRowAtIndexPath:被调用。

这意味着如果一个单元格被点击的次数是奇数(1,3,5,…),那么总是tableView didSelectRowAtIndexPath:将被调用,如果一个单元格被点击的次数是偶数(2,4,6,…),那么总是tableView didDeselectRowAtIndexPath:将被调用。

这使得tableView didSelectRowAtIndexPath:函数在同一单元格的第三个选择时被调用,因此结果是双击调用didSelectRowAtIndexPath:!!

如果你想让tableView didSelectRowAtIndexPath:在每个单元格的选择上被调用那么tableView multiple selection必须设为false, tableView。allowmultipleselection = false。

通过这样做,每次单元格被点击tableView didSelectRowAtIndexPath:将被调用在表格视图中,通过选择另一个单元格tableView didDeselectRowAtIndexPath:将被调用在单元格之前被选中,然后tableView didSelectRowAtIndexPath:将被调用在新选中的单元格。

    class TableViewController: UITableViewController {
    
    override func viewDidLoad() {
        super.viewDidLoad()

        tableView.allowsMultipleSelection = false
    }

    override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        print("This will be called for each cell tap")
    }