一、刷新时界面跳动“乱跑”的现象
1.原因
Apple在iOS 8 中引入Self-Sizing,我们可以通过实现 estimatedRowHeight 相关的属性来展示动态的内容,实现了 estimatedRowHeight 属性后,得到的初始 contentSize 是个估算值,是通过 estimatedRowHeight * cell 的个数得到的,并不是最终的 contentSize,tableview 不会一次性计算所有的 cell 的高度,只会计算当前屏幕能够显示的 cell 个数在加上几个,滑动时,tableview 不停地得到新的 cell,更新自己的 contentSize,在滑倒最后的时候,会得到正确的 contentSize。
利用Self-Sizing技术,我们不需要实现heightForRowAt方法,系统通过AutoLayout约束自动计算cell高度并绘制显示。
在iOS 11 之后,UITableView 的 Headers、Footers 和 Cells都默认开启了 Self-Sizing,所以 estimated 高度默认值从iOS11之前的 0 改变为了 UITableViewAutomaticDimension(-1),如果项目中没有使用 estimatedRowHeight 属性,在 iOS 11 的环境下就要注意了,因为在估算行高机制下,contentSize 的值是一点点地变化更新的,所有的cell显示完后才是最终 contentSize 值,因为不会缓存正确的行高,tableView reloadData 的时候,会重新计算 contentSize,就有可能会引起 contentOffset 的变化,