进行了几次尝试之后,发现在 collectionView 没有显示的时候,是不会进行 cell视图 的渲染的,也就是说当前的 collectionView 中没有cell类别的子视图,此时直接加入子视图会在渲染cell类别子视图之前,而当 collectionView 可见的时候, collectionView 再去渲染显示 cell (推测系统可能使用insertView:Index:方法),此时让 cell 层级插入到了 UICollectionView 与刚刚加到 CollectionView 视图之间了,进而导致了当前的问题的发生。
知道原因了,再去解决这样的问题,就很方便了。我们可以将 View 的添加放在渲染 cell 之后,这样就能避免系统渲染 cell 影响我们视图的层级结构导致画面被遮挡的问题了。
在进行 CollectionView reload之后,我们可以强制 CollectionView 渲染界面,使用 layoutIfNeeded 进行界面的强制刷新,之后再去插入我们想加入的视图,这样就能将加入的视图放入到 UICollectionView 与 Cell 之间了,从而达到我们想要的效果。
uitableview cell 添加子视图xib为什么frame跟设置的不一样有时候我们经常需要自定义tableView的cell,当cell里面的布局较为复杂时往往舍弃纯代码的方式而改用xib的方式进行自定义。当我们用纯代码的方式布局cell时,往往会在cell的initWithStyle: reuseIdentifier: 方法里面用纯代码进行布局,然后在外部VC的cellForRowAtIndexPath方法里面我们会这么写,假定自定义的cell为Cell,继承自UITableViewCell:
static NSString *CellIdentifier = @"Cell"
Cell *cell = (Cell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier]
if (!cell) {
cell = [[[Cell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease]
}
cell.titleLabel.text = [self.dataList objectAtIndex:indexPath.row]
return cell
上述这么写完全没有问题,因为教科书跟各种教程都是这么写的,上述代码对cell进行了重用。但如果我们现在想用xib来布局呢?看到过不少代码是这么写的:
static NSString *CellIdentifier = @"Cell"
Cell *cell = (Cell *)[tableView dequeueReusableCellWithIdentifier:CellIdentifier]
if (!cell) {
cell = [[[NSBundle mainBundle] loadNibNamed:NSStringFromClass([Cell class])
owner:self
options:nil] objectAtIndex:0]
//cell = [[[Cell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier] autorelease]
}
cell.titleLabel.text = [self.dataList objectAtIndex:indexPath.row]return cell
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)