赞
踩
这是我第一篇博文,希望各位支持
直奔主题吧,细心的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的时候添加下面几行代码就搞定了
- for (UIView *subView in tabView.subviews) {
- if ([subView isKindOfClass:[UIScrollView class]]) {
- ((UIScrollView *)subView).delaysContentTouches = NO;
- }
- }
在collectionview上也是同理,不过collection上好像很少有人防按钮吧~~~遇到了就这么办就行,各位一定要记住啊,在tableview和cell之间是有个UITableViewWrapperView存在的,有时你需要在cell上添加按钮,按钮的点击事件里需要操作tableview的时候,获取那个按钮有几个superview你可一定要数明白啊~~~
望各位多多支持,有错误尽管喷,嘿嘿
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。