当前位置:   article > 正文

解决tableview上按钮点击效果的延迟现象_tableview 延迟

tableview 延迟

这是我第一篇博文,希望各位支持

直奔主题吧,细心的iOS程序员应该能注意到在tableview上添加的按钮的点击效果有延迟的现象,当然有人直接忽略了那点延迟或者觉得那就是苹果的问题,实则不然,那是苹果的scrollview的一个属性,假入你在scrollview上添加按钮,也是一样会有那种效果,就是你点击按钮时,按钮不会立刻进入高亮状态,而是你长按时才会进入高亮状态

接下来各位小伙伴们就好懂了,但各位不要以为直接把tableview的这个属性设置为NO就完事了,但你把tableview的delaysContentTouches属性设置为NO后,只会让你的tableview的Header和Footer上的按钮的高亮状态不再延迟,而在cell上的按钮还是会有高亮状态延迟的效果,这又是为什么呢,这是因为在tableview与cell之间还有一个继承与scrollview的view,他的名字叫UITableViewWrapperView,cell是放在这个UITableViewWrapperView上的,这个UITableViewWrapperView与Footer和Header是同一层级,都是tableview的subview

 

 

 

这就是为什么在tableview上的按钮点击时的高亮状态会有延迟效果了,解决方法也很简单,只需在创建tableview的时候添加下面几行代码就搞定了

  1. for (UIView *subView in tabView.subviews) {
  2. if ([subView isKindOfClass:[UIScrollView class]]) {
  3. ((UIScrollView *)subView).delaysContentTouches = NO;
  4. }
  5. }


在collectionview上也是同理,不过collection上好像很少有人防按钮吧~~~遇到了就这么办就行,各位一定要记住啊,在tableview和cell之间是有个UITableViewWrapperView存在的,有时你需要在cell上添加按钮,按钮的点击事件里需要操作tableview的时候,获取那个按钮有几个superview你可一定要数明白啊~~~

望各位多多支持,有错误尽管喷,嘿嘿

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/93600
推荐阅读
相关标签
  

闽ICP备14008679号