UITableView自动计算cell高度并缓存(Xib)
2016-11-16 00:00
447 查看
这篇文章我们来讲一下UITableView的cell自适应高度,以及遇到的问题的解决办法。在看文章之前希望你已经会UITableView的基本使用了。 先奉上这篇文章的demo的Github地址:UITableViewCellHeightDemo。大家可以下载下来和文章配合看。 cell高度计算的历史在iOS8之前,如果UITableViewCell的高度是动态的,如果想要显示正确的话,我们需要在下面这个UITableView的代理方法中,返回每一行的精确高度:
后来也有一些人写了一些第三方去解决这个问题,例如UITableView-FDTemplateLayoutCell。只要给cell自上而下加好约束,它就可以帮我们去算cell的高度并且可以缓存,省去了我们自己写计算代码的成本。具体可以进链接里面看看它的demo。 但是在iOS10的系统下, FDTemplateLayoutCell会卡界面,而且tableview的行数越多表现的越卡。 而且苹果在iOS8之后,推出了一种超级简单的cell动态自适应的方法,使用起来比 FDTemplateLayoutCell也简单一些,而且现在iOS10都出来了,没有必要去支持iOS7了,所以最后我还是选择了用系统的办法。这样我们以后就再也不用写 heightForRowAtIndexPath方法了哈哈哈。 系统的cell自适应高度的使用方法首先我们需要把cell上的控件自上而下加好约束,如果对约束不熟悉的话建议看看下面这两篇文章学习一下:Auto Layout Tutorial in iOS 9 Part 1: Getting Started(http://www.raywenderlich.com/115440/auto-layout-tutorial-in-ios-9-part-1-getting-started-2) [Auto Layout Tutorial in iOS 9 Part 2: Constraints 用xib加约束和用masonry加代码约束都是可以的。注意约束一定要自上而下加好,让系统知道怎么去计算高度。在这篇文章的demo里面的cell加的约束是这样的: cell约束 加好约束后,然后告诉tableView自己去适应高度就可以了。有两种写法:
来看下demo效果: 我们看到,cell已经自己适应内容算出了高度,是不是很方便呢哼哼。 具体的代码大家可以去demo看哦。 其实section的header和footer也是可以自动适应的,对应的方法有:
可能遇到的问题和解决办法1.高度不对有时候有可能运行出来后看到cell的高度显示的不对,就像这样: 这个问题是因为约束没有满足自上而下,从而系统不知道怎么去计算。解决办法就是去修改约束,直到满足为止。一定要好好理解约束啊! 2.点击状态栏无法滚动到顶部 我们知道,如果界面中有UIScrollView的话,点击状态栏会让其滚动到顶部,就像这样: 但是如果我们用了自动计算高度的方法,又调用了tableView的reloadData方法(例如我们的数据有分页的时候,加载完下一页的数据后会去刷新tableView)。这时候就会出现问题,点击状态栏就有几率不能精确滚动到顶部了: 解决这个问题的办法是去缓存cell的高度,代码如下:
缓存高度之后,在demo里面多试几次,发现点击状态栏已经可以精确滚动回顶部了: 这段代码其实可以写在viewController的基类里面,这样写一遍就可以每个地方都能缓存cell的高度了。详见demo。这样就完美了! 原文:http://bbs.520it.com/forum.php?mod=viewthread&tid=2794&page=&extra=#pid30294 |
相关文章推荐
- UITableView自动计算cell高度并缓存,再也不用管高度啦
- UITableView自动计算cell高度并缓存
- UITableView自动计算cell高度并缓存,再也不用管高度啦
- UITableView自动计算cell高度并缓存
- UITableView自动计算cell高度并缓存
- cell自动计算高度(masonry与UITableView-FDTemplateLayoutCell)
- UITableView自动计算cell的高度
- iOS8+ UITableView自动计算cell高度并缓存
- UITableView自动计算cell高度
- UITableView性能优化---自动计算cell高度(FDTemplateLayoutCell)
- 四种方法实现UITableView的cell高度自动计算
- UITableView tableFooterView autolayout自动计算高度
- iOS开发——UITableView优化之缓存cell高度
- UITableView 如何不动态计算返回的cell 的高度
- xib 手动拖uitableview 高度自动默认下移
- 基于MVC的自动计算Cell高度的TableView的使用
- ios tableview 自动计算cell高度
- 使用UITableView+FDTemplateLayoutCell计算cell的高度
- 缓存cell高度开源代码阅读:UITableView-FDTemplateLayoutCell
- UITableView自动调整Cell高度