iOS UITableView 表头、表尾、段头、段尾 的坑(二)

一、概述
  • 本文主要是针对在iOS开发中,UITableView表头、表尾、段头、段尾的开发过程中的遇到的细坑以及填坑的处理方式。
  • UITableView是我们在iOS开发中经常使用到一种可视控件,UITableView的类型分为两种:UITableViewStyleGroupedUITableViewStylePlain. tableView的默认的类型是UITableViewStylePlain
  • 希望能为广大开发提供一点思路,少走一些弯路,填补一些细坑。
二、细坑

UITableView设置类型UITableViewStylePlain页面显示正常,但设置类型为UITableViewStyleGroupedtableView顶部距离导航栏底部有段距离,且你设置0无效。如下图所示:

  • UITableViewStylePlain效果图

  • UITableViewStyleGrouped 效果图

    UITableViewStyleGrouped@2x.png

据分析,iOS7在tableView样式设置为UITableViewStyleGrouped后,默认设置了Header的高度。

三、填坑
  1. 方法一:设置的tableHeaderView高度为特小值 (切记不能为零,若为零的苹果会取默认值)
    // 注意:这种设置方式才有效,下面三种设置无效
    tableView.tableHeaderView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, MHMainScreenWidth, CGFLOAT_MIN)];
//    tableView.tableHeaderView = nil;
//    tableView.tableHeaderView = [[UIView alloc] init];
//    tableView.tableHeaderView = [[UIView alloc] initWithFrame:CGRectZero];
  1. 方式二:实现UITableViewDelegate方法(切记不能返回0,否则等于没设置,会走苹果的默认值。iOS UITableView 表头、表尾、段头、段尾 的坑(一)))
   - (CGFloat) tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section
  {
      return CGFLOAT_MIN; // .001f
  }
  1. 方式三:设置tableViewcontentInset,该Demo中默认的tableView.contentInset.top = 64,经过滚动调试,确认当tableViewheader底部滚动到导航栏的底部时,tableView.contentOffset.y = -29 , 默认等于-64,于是即可得应该设置tableView.contentInset = UIEdgeInsetsMake(29, 0, 0, 0);,其实不然,这样会导致tableView.contentInset.top = 64+29,因为tableView会在tableView.contentInset.top = 29的情况下,在往下偏移64像素。这里所以应该设置为29-64即可。

/// 设置tableView的contentInset
self.tableView.contentInset = UIEdgeInsetsMake(-35, 0, 0, 0);
```

四、拓展
  1. 去除tableView上底部多余的分割线。
    tableView.tableFooterView = [[UIView alloc] init];
五、期待
  1. 文章若对您有点帮助,请给个喜欢❤️,毕竟码字不易;若对您没啥帮助,请给点建议💗,切记学无止境。
  2. 针对文章所述内容,阅读期间任何疑问;请在文章底部评论指出,我会火速解决和修正问题。
  3. GitHub地址:https://github.com/CoderMikeHe
六、代码

MHDevelopExample_Objective_C - MHUITableViewStyleGroupedBugController.h/m

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容