我正在开发一个带有故事板的iOS 5项目,因此在IB中使用动态表格单元原型。在其中一个视图中,我有一个带有可变高度单元格的表格视图,单元格高度是根据内容的高度计算的。
首次显示表视图时, tableView:heightForRowAtIndexPath:
将返回所有单元格的正确值。当向下滚动几个项目时,一切都很好,但随后出现问题:实际单元格似乎是正确的高度,包括它们的触摸区域,但它们的分隔符在错误的位置(在单元格内而不是它们之间)呈现。 / p>
从测量分隔符位置开始,似乎单元格重用可能与此有关。前三个单元格的分隔符正确呈现,但不是第四个。 heightForRowAtIndexPath:
返回正确的高度(本例中为125像素),其包含的子视图都在正确的位置。但是,分隔符仅从前一个分隔符渲染108个像素,将其放置在单元格的125像素高区域内。
这是踢球者:108px是第一个表格单元格的高度,现在看不见了,可能会重复使用。我没有明确的证据,但似乎表视图忽略了heightForRowAtIndexPath:
这些单元格,只是根据重用的单元格高度渲染分隔符。
这并不能解释为什么一堆较晚的较短单元格根本不会呈现分隔符。但这就是我必须继续下去的事情。
是否有解决方法,IB设置或其他可能有用的内容?
答案 0 :(得分:22)
我有同样的问题,分隔符在看似随机的位置显示。
原来问题是我覆盖了layoutSubviews
,但忘了拨打[super layoutSubviews]
。添加该调用可以解决我的问题。
答案 1 :(得分:1)
我也遇到了这个奇怪的问题。对于自定义表格单元格,添加图层作为分隔符可能是更好的选择。
在自定义表格单元类的initWith ***方法中:
separator = [CALayer layer];
separator.backgroundColor = [UIColor colorWithWhite:0.8f alpha:1.0f].CGColor;
[self.layer addSublayer:separator];
在layoutSubviews方法中更新分隔符的框架:
- (void)layoutSubviews {
CGFloat height = 1.0f;
separator.frame = CGRectMake(0.0f, self.frame.size.height - height, self.frame.size.width, height);
[super layoutSubviews];
}