ios tableview cellheight
来源:互联网 发布:java售楼管理系统 编辑:程序博客网 时间:2024/05/17 23:43
UITableview是iOS开发中使用最频繁的一个控件,在实际开发中,我们经常需要定制cell,让cell显示图片、文字等。由于cell包含的图片和文字是根据服务器返回的数据进行填充的,这就导致cell包含的内容的高度是不定的。
四种方法计算cell的高度:
1、iOS8的自动计算机制,需要autolayout(适用iOS8之后系统)
2、iOS6之后系统API结合autolayout进行计算(适用于iOS6之后的系统)
3、手动计算(适用于iOS6之后的系统)
4、借助于第三方框架自动计算(适用于iOS6之后的系统)
方法1:iOS8的自动计算
此方法必须使用autolayout,这里我是用的xib设置的,也可以使用第三方框架masonry设置。
设置约束的时候必须注意每个控件在垂直方向上必须都有约束,这样cell才可以计算出来高度。
下面我们来看看cell的内部控件的垂直方向的约束如何设置
昵称label的垂直约束
内容图片的垂直约束
height <= 400这个约束也可以不用设置,我这里是为了不让图片过长,所以限制了高度。
具体实现代码
iOS8时代的高度计算非常简单,下面两行代码就搞定了,非常方便。
前提是需要设置好在垂直高度上的约束。
效果如下
方法2:iOS6的系统API结合autolayout
控件的约束和第一个方法的一样,下面列出的代码是和第一个方法不同的地方。该方法的demo和第一个方法的demo是同一个,每个方法独立使用到的代码我会特别注明,没有注明就是所有方法共有的。
该方法实现效果和方法一相同
方法3、手动计算
该方法需要手动计算垂直高度上每个控件的高度,然后相加得出cell的高度。
这种方法最繁琐,但是也是最精确的,也是最可控的。
使用这个方法,可以不需要使用autolayout设置约束,直接使用frame设置每个控件的位置。但是为了方便,我这里还是使用autolayout设置控件的约束和位置。
因为需要确切的知道每个控件的高度,所以这里image的高度必须是固定的,这样才可以进行cell的高度计算
修改如下
修改的代码如下:
方法四、使用第三方框架
这是国内的一个大神写的框架,可以一行代码就实现cell的高度自动计算。同时还能实现缓存高度,最低兼容版本为iOS6。
实现代码就不写了,非常简单
具体看这篇文章:《优化UITableViewCell高度计算的那些事》
这里啰嗦两点,也是自己踩过的坑:
1、在博主的文字里面提到使用的时候直接使用如下代码即可:
一定要把上面的id cell,换成自己的cell类,比如我的就是WSTableViewCell *cell。算是一个小坑吧。
2、很多人肯定吃过self-sizing-cell的亏,觉得我上面都设置对了,为什么就是算不出来高度呢?
要满足self-sizing-cell,必须满足两点:
- 你的cell里面的控件必须在上下左右四个方向都有约束到cell的四个边。如下图:
*约束一定要是控件和cell的contentView边缘之间的约束,而不是控件和cell边缘的之间的约束。
因为设计给的图,cell内部的控件和cell的距离是到cell边缘的距离,然后我就发现怎么都不能进行高度自动计算,所有的cell全部叠在一起了。被这个坑了很久,一直找不出来原因。另外cell的边缘和cell的contentView的边缘相差8pt。
错误设置:
ReplayCell是cell的名字
正确设置:
superView是cell的contentView
总结:
上面四种方法各有优缺点,如果你的App最低兼容版本是iOS8,那请毫不犹豫的选择方法一的系统方法吧,高效简洁。
如果你需要最低兼容iOS6,可以从其他三个方法中选一个,建议使用方法四的第三方框架,高效强大。
所有的代码都放在了Github上面,小伙伴们可以参考下。
地址如下:https://github.com/XiMu-Demo/Blog-Demo/tree/master/calculateCellHeight
- ios tableview cellheight
- ios tableview
- iOS tableView
- TableView iOS
- ios tableview
- iOS---tableview
- [iOS]TableView
- iOS tableView
- IOS TableView 详解
- IOS tableView常用属性--
- IOS控件-tableview
- IOS中的tableview
- iOS tableView事件方法
- ios tableView 的使用
- IOS tableView数据显示
- ios--遍历Tableview
- ios TableView 一般操作
- [IOS]Tableview分组
- OpenCV的安装配置
- 使用EasyDarwin实现RTSP视频监控、直播推送
- 磁盘结构
- Android中startActivity和sendBroadcast不能共用一个intent
- android 5.0的颜色
- ios tableview cellheight
- 约瑟夫环问题【数组】
- android调用应用市场进行软件评分
- 第一行代码笔记 一个下载的demo
- 关于使用js插件ckeditor报错的解决办法
- [故障公告]博客站点遭遇超过20G的流量攻击被阿里云屏蔽
- 电路板焊接完毕测试方法
- highchart js自定义坐标(解决自递增问题)
- iOS引导页、启动页