在首先个 Section 的方面拖进来八个空 UIView 

率先个section上面多余间隔管理

// 隐藏UITableViewStyleGrouped上边多余的间隔
_tableView.tableHeaderView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 0, CGFLOAT_MIN)];

各样section上面多余间距管理

// 隐藏UITableViewStyleGrouped下边多余的间隔
- (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section {
    return CGFLOAT_MIN;
}
  • 备考:若传入的 height == 0,则 height 被设置成私下认可值
  • 若 height
    小于显示屏半像素对应的惊人,则不会被渲染,所以那边重返CGFLOAT_MIN,其实重返0.01也是能够的

补偿:代码顺序的区别形成第两个section上边现身多余间隔

  • 在安装代理设置tableFooterView,上边会出现结余间隔

tableView = [[UITableView alloc]initWithFrame:CGRectZero style:UITableViewStyleGrouped];
tableView.tableFooterView = [UIView new];
tableView.delegate = self;
tableView.dataSource = self;
  • 在安装代理设置tableFooterView,上边不会出现剩下间距

tableView = [[UITableView alloc]initWithFrame:CGRectZero style:UITableViewStyleGrouped];
tableView.delegate = self;
tableView.dataSource = self;
tableView.tableFooterView = [UIView new];
  • 能够透过第一个section上边多余间距处理的方法来灭亡因代码顺序诱致的上述难题,所以这里提出要解决第一个section上边多余间距只怕经过小说开始所说的清除办法越来越好

在 Storyboard 中 0 代码化解

没用 Storyboard 的同学利用方面包车型客车代码就 OK 了; 而在 Storyboard 中得以 0
代码解决这些事: 

第风度翩翩,在第八个 Section 的地方拖进来贰个空 UIView 

图片 1

然后选中那一个 UIView 的 Runtime Attributes 栏,增多一个 frame 的
KeyPath 

图片 2

这般底部的间距就乖乖的不见了: 

图片 3

寻根究底 UITableViewHeader 的猫腻

怎么刚才说 0.1 和 CGFLOAT_MIN
是同样的呢?经过探究,这几个高度值的震慑大致是那般的:

  1. 若传入的 height == 0,则 height 被安装成默许值
  2. 若 height 小于显示器半像素对应的可观,这几个 header 不在另叁个像素渲染

半像素也便是 1.0 / scale / 2.0,如在 @2x 屏上是 0.25
直观的心得下,假设这几个 height 被设置成 0.5 的指南:
图片 4

导航栏下边的阴影线看上去宽了 0.5 像素的,Done。

参照小说

相关文章