美文网首页ios学习资料tableview&&小知识点
iOS UITableView 表头、表尾、段头、段尾 的坑(二

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

作者: CoderMikeHe | 来源:发表于2017-03-07 12:55 被阅读1124次
    一、概述
    • 本文主要是针对在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

    相关文章

      网友评论

      • 93b3d3ccb7e6:坑爹,A界面这样写没问题:tableView.tableHeaderView = UIView()

        B界面却非得这样写:tableView.tableHeaderView = UIView.init(frame: CGRect.init(x: 0, y: 0, width: 0.1, height: 0.1))

        :flushed:
        CoderMikeHe:@书中觅宝 哈哈哈,苹果的问题。
      • 2f80e1ba9390:一个字,不错
      • beb57d443acc:写的真好~太有用了!

      本文标题:iOS UITableView 表头、表尾、段头、段尾 的坑(二

      本文链接:https://www.haomeiwen.com/subject/pgbpgttx.html