如何让UITableView的section headerView不悬停

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">在项目开发过程中使用UITableView时,UI设计的列表页中,每一个cell的头部会有一条粗的间隔线,隔开每个cell,这个时候有几个问题:</span>
1.如果让线与cell设为一体,当点击cell时,线会与cell一同高亮,实际应该是线不高亮;

2.线作为每个cell的headerView,这个时候会出现这条粗线一直置于顶部的问题。

本篇文章就是讨论第二个问题的解决方法。

通过在网上搜索相关问题,发现如下解决方法:

1.将UITableView的style设置为Group。

2.通过设置UIScrollView的contentInset属性,代码如下:

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    CGFloat sectionHeaderHeight = 40;
    if (scrollView.contentOffset.y<=sectionHeaderHeight&&scrollView.contentOffset.y>=0) {
        scrollView.contentInset = UIEdgeInsetsMake(-scrollView.contentOffset.y, 0, 0, 0);
    } else if (scrollView.contentOffset.y>=sectionHeaderHeight) {
        scrollView.contentInset = UIEdgeInsetsMake(-sectionHeaderHeight, 0, 0, 0);
    }
}
这是原出处的地址: http://www.tuicool.com/articles/niuQZjm

------------------------------------------------------------------------------关于第二个方法原理的解释:

通过查contentInset这个属性,它是UIEdgeInset类型,包含top,bottom,left,right几个值,由此我们可以看到,上述方法的作用是根据scrollView的滚动设置scrollView的content与容器上下左右的距离去控制其显示。

这里有关于contentInset这个属性介绍的PPT,可以帮助理解:http://www.docin.com/p-120039524.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值