【问题标题】:Assert no index path for table cell being reused断言重复使用的表格单元格没有索引路径
【发布时间】:2017-08-05 06:32:11
【问题描述】:

我有一个UITableView,其中包含自定义UITableViewCells,其中包含UITextFields。

我想在用户点击单元格时显示键盘。我正在做这样的事情:

func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {

     guard let cell = tableView.dequeueReusableCell(withIdentifier: "FormCell", for: indexPath) as? FormTableViewCell else {
        return
     }

    cell.textField.becomeFirstResponder()
}

但是当我在 iPad 上运行应用程序时,点击单元格并尝试使用“关闭键”关闭键盘,我收到此错误:

[Assert] 没有重复使用表格单元格的索引路径

这是我得到的全部错误:

* thread #1: tid = 0x7f323, 0x00000001021d5cd8 libswiftFoundation.dylib`static Foundation.IndexPath._unconditionallyBridgeFromObjectiveC (Swift.Optional<__ObjC.NSIndexPath>) -> Foundation.IndexPath + 56, queue = 'com.apple.main-thread', stop reason = EXC_BREAKPOINT (code=1, subcode=0x1021d5cd8)
  * frame #0: 0x00000001021d5cd8 libswiftFoundation.dylib`static Foundation.IndexPath._unconditionallyBridgeFromObjectiveC (Swift.Optional<__ObjC.NSIndexPath>) -> Foundation.IndexPath + 56
frame #1: 0x00000001010ab9ec PullToDismiss`@objc PullToDismiss.tableView(UITableView, didEndDisplaying : UITableViewCell, forRowAt : IndexPath) -> () + 104 at PullToDismiss+Proxy.swift:0
frame #2: 0x000000018fb29c9c UIKit`-[UITableView _reuseTableViewCell:withIndexPath:didEndDisplaying:] + 304
frame #3: 0x000000018fa13b58 UIKit`-[UITableView _setIsAncestorOfFirstResponder:] + 1028
frame #4: 0x000000018f8bc288 UIKit`+[UIView(Internal) _setIsResponderAncestorOfFirstResponder:startingAtFirstResponder:] + 216
frame #5: 0x000000018f8bc02c UIKit`-[UIWindow _setFirstResponder:] + 112
frame #6: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #7: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #8: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #9: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #10: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #11: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #12: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #13: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #14: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #15: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #16: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #17: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #18: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #19: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #20: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #21: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #22: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #23: 0x000000018fb973bc UIKit`-[UIResponder _setFirstResponder:] + 80
frame #24: 0x000000018fae6ec0 UIKit`-[UIView _setFirstResponder:] + 92
frame #25: 0x000000018f928ecc UIKit`-[UITextField _resignFirstResponder] + 300
frame #26: 0x000000018f8ff374 UIKit`-[UIResponder _finishResignFirstResponder] + 296
frame #27: 0x000000019024d2d0 UIKit`-[UITextField _finishResignFirstResponder] + 52
frame #28: 0x000000018f8a36d0 UIKit`-[UIResponder resignFirstResponder] + 284
frame #29: 0x000000018f928bc8 UIKit`-[UITextField resignFirstResponder] + 136
frame #30: 0x000000018fc25978 UIKit`-[UIKeyboardImpl dismissKeyboard] + 544
frame #31: 0x000000018f9be760 UIKit`-[UIKeyboardLayoutStar continueFromInternationalActionForTouchUp:withActions:timestamp:interval:didLongPress:prevActions:executionContext:] + 2544
frame #32: 0x000000018f9bdb7c UIKit`-[UIKeyboardLayoutStar completeSendStringActionForTouchUp:withActions:timestamp:interval:didLongPress:prevActions:executionContext:] + 784
frame #33: 0x000000018f9b1684 UIKit`-[UIKeyboardLayoutStar completeRetestForTouchUp:timestamp:interval:executionContext:] + 4712
frame #34: 0x000000018fc3211c UIKit`__45-[UIKeyboardLayout touchUpTaskForTouchState:]_block_invoke + 228
frame #35: 0x000000018f821b14 UIKit`-[UIKeyboardTaskQueue continueExecutionOnMainThread] + 384
frame #36: 0x000000018fc31dd0 UIKit`-[UIKeyboardLayout _touchEndedProcessingForTouches:] + 344
frame #37: 0x000000018f82c0c4 UIKit`-[UIWindow _sendTouchesForEvent:] + 2484
frame #38: 0x000000018f827328 UIKit`-[UIWindow sendEvent:] + 2988
frame #39: 0x000000018f7f7da0 UIKit`-[UIApplication sendEvent:] + 340
frame #40: 0x000000018ffe175c UIKit`__dispatchPreprocessedEventFromEventQueue + 2736
frame #41: 0x000000018ffdb130 UIKit`__handleEventQueue + 784
frame #42: 0x00000001898f6b5c CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 24
frame #43: 0x00000001898f64a4 CoreFoundation`__CFRunLoopDoSources0 + 524
frame #44: 0x00000001898f40a4 CoreFoundation`__CFRunLoopRun + 804
frame #45: 0x00000001898222b8 CoreFoundation`CFRunLoopRunSpecific + 444
frame #46: 0x000000018b2d6198 GraphicsServices`GSEventRunModal + 180
frame #47: 0x000000018f8627fc UIKit`-[UIApplication _run] + 684
frame #48: 0x000000018f85d534 UIKit`UIApplicationMain + 208
frame #49: 0x00000001003da970 `main + 140 at AppDelegate.swift:15
frame #50: 0x00000001888055b8 libdyld.dylib`start + 4

然后应用程序就崩溃了。如果我将UITableView 滚动到顶部,它也会崩溃。我怎样才能防止这种情况发生?

【问题讨论】:

  • 1.切勿在cellForRowAt 之外使用dequeueReusableCell。 2. 哪一行代码实际导致了崩溃?提供有关崩溃的更多详细信息。
  • @rmaddy 我添加了我得到的整个错误
  • PullToDismiss 是您的课程之一吗?如果是这样,edit 使用其 didEndDisplaying 方法提出您的问题。
  • @rmaddy PullToDismiss 是第三方类,您的建议和@JuicyFruit 的回答有效,谢谢

标签: ios swift uitableview ipad


【解决方案1】:

尝试这种方法来获取单元格,你正在做的是创建一个新的。

if let cell = tableView.cellForRow(at: indexPath) as? FormTableViewCell {
    cell.becomeFirstResponder
} else {
..dostuff
}

【讨论】:

  • 如果cellForRow 引用了一个不在屏幕上的indexPathcell 为零。为了避免这种情况,可以先scrollToRow 确保它在屏幕上,但cellForRowAt 不会及时发生,cellForRow 仍然会失败。有什么避免这种情况的想法吗?
  • 我回答了我自己的问题。将scrollToViewanimated 参数设置为false。它不像动画那么漂亮,但至少它有效。
猜你喜欢
  • 2013-08-31
  • 1970-01-01
  • 1970-01-01
  • 2014-10-17
  • 1970-01-01
  • 1970-01-01
  • 2011-02-02
  • 1970-01-01
  • 2018-08-10
相关资源
最近更新 更多