在找到解决方案之前,我试图解决这个问题两天。 在这里。
==
大家好,
我实际上使用委托方法heightForRowAtIndexPath来管理iOS7中tableViewCell的高度:
现在,在iOS8中,我使用属性tableView.rowHeight = UITableViewAutomaticDimension和autolayout,它比以前更好,更好。
问题是我需要从我的代码中删除heightForRowAtIndexPath:方法,否则该属性不起作用(高度设置在内部并控制属性)。
如何才能在iOS8中删除此方法(可能使用编译指令,但我不知道哪一个)?
我仍然需要ios7。
答案 0 :(得分:4)
尝试这个
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath
{
if(IS_IOS8){
return UITableViewAutomaticDimension;
}
else
{
int height; // your custom calculated height
return height;
}
}
答案 1 :(得分:1)
我也有这个问题,所以看看这里:
1)我们需要创建宏
#define SYSTEM_VERSION_LESS_THAN(v) ([[[UIDevice currentDevice] systemVersion] compare:v options:NSNumericSearch] == NSOrderedAscending)
2)需要在viewWillAppear中检查版本
- (void)viewWillAppear:(BOOL)animated
{
[super viewWillAppear:animated];
if (![self.p_tableView respondsToSelector:@selector(tableView:heightForRowAtIndexPath:)])
{
self.p_tableView.rowHeight = UITableViewAutomaticDimension;
self.p_tableView.estimatedRowHeight = 100.0f;
}
}
3)我们需要覆盖respondsToSelector方法,这种方式需要更少的资源消耗,因为我们不需要为每一行调用heightForRow
- (BOOL)respondsToSelector:(SEL)selector
{
static BOOL useSelector;
static dispatch_once_t predicate = 0;
dispatch_once(&predicate, ^{
useSelector = SYSTEM_VERSION_LESS_THAN(@"8.0");
});
if (selector == @selector(tableView:heightForRowAtIndexPath:))
{
return useSelector;
}
return [super respondsToSelector:selector];
}
希望有所帮助
答案 2 :(得分:1)
您仍然可以使用tableView:heightForRowAtIndexPath:
- (void)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath {
return UITableViewAutomaticDimension;
}