原创文章,转载请注明出处:http://blog.csdn.net/jasonchen2009/article/details/44307329
UITableView是iOS开发中最为常见的视图控件了,现在大多数App可能都是支持iOS7以上版本,相信大家也曾经或将要遇到UITableView或UITableViewCell在不同版本中的兼容性问题,这里做了一点简单总结。
在iOS7中:
UITableView
~~~~UITableViewWrapperView
~~~~~~~~UITableViewCell
~~~~~~~~~~~~UITableViewCellScrollView
~~~~~~~~~~~~~~~~UITableViewCellContentView
~~~~~~~~~~~~~~~~~~~~UILabel
(UITableViewCellScrollView是什么?http://www.curiousfind.com/blog/646)
UITableView
~~~~UITableViewCell
~~~~~~~~UITableViewCellContentView
~~~~~~~~~~~~UILabel
场景1:通过UILabel获取到UITableViewCell
方案:
UIView *upperView = cell.label.superview;
while(upperView && ![upperView isKindOfClass:[UITableViewCell class]])
{
upperView = upperView.superview;
}
return upperView;
场景2:获取到UITableViewCellScrollView
方案:
if(![cell.contentView.superview isKindOfClass:[UITableViewCell class]])
{
UIView *cellScrollView = cell.contentView.superview;
// Action on UITableViewScrollView
// ...
}
场景3:由UITableViewCell获取到UITableView
方案A:
id view = [tableViewCellInstance superview];
while (view && ![view isKindOfClass:[UITableView class]])
{
view = [view superview];
}
UITableView *tableView = (UITableView *)view;
方案B:自建一个 UITableViewCell的 Category
@implementation UITableViewCell(RelatedTableView)
- (UITableView *)relatedTableView
{
if ([self.superview isKindOfClass:[UITableView class]])
{
// For iOS6 and iOS8
return (UITableView *)self.superview;
}
else if([self.superview.superview isKindOfClass:[UITableView class]])
{
// For iOS7
return (UITableView *)self.superview.superview;
}
else
{
NSAssert(NO, @"UITableView shall always be found.");
return nil;
}
}
@end
方案C:多数情况下我们的 cell 是自定义的 UITableViewCell的子类,所以可以在我们的cell中添加一条属性,
@interface MyUITableViewCell
@property (weak, nonatomic) UITableView *relatedTableView;
@end
(为什么是weak?循环引用带来内存泄露。)
在cellForRowAtIndexPath方法中顺便把自定义cell对应的UITableView赋给cell.relatedTableView。
参考:
http://stackoverflow.com/questions/15711645/how-to-get-uitableview-from-uitableviewcell
http://stackoverflow.com/questions/19162725/access-ios-7-hidden-uitableviewcellscrollview