UITableViewCell高度自适应的关键点

iOS开发中对于UITableViewCell高度自适应的文章已经很多很多,但如果cell内容比较复杂,刚使用autolayout配置自使用时还是总不能一次性成功。

KEY POINT

这里只说设置的关键一点:

Cell内部的Constraints一定要有一条从Cell顶部到底部的一条可联通线。

图例列表:

Paste_Image.png

Paste_Image.png

Paste_Image.png

最后顶部元素居上和底部元素距底部,加上约束即可。
这条线上可以有固定高度的元素,可以有自适应高度的元素,但要保证:

设置自适应高度的元素都在这条线上。

当然如果在同一水平上有两个需要自适应高度的元素,就有择其一了。

OTHER POINTS

其他注意要点:

  1. 确保在设置约束之前,UITableViewCellsize inspector里面 Row HeightDefault而不是custom的数值,否则之后不管你如何操作,UITableViewCell优先使用的都是custom的数值。

    Paste_Image.png

  2. 注意语句.
    _tableView.estimatedRowHeight=44.0;

    如果没有这一行,依然无法自动布局。

  3. 注意设置自适应高度Label lines0
    人总是容易忽略最简单的问题。

Paste_Image.png

LAST

最后在代码文件中,添加代码:
iOS8
使用iOS8新出的方法:

self.tableView.estimatedRowHeight=44;
self.tableView.rowHeight=UITableViewAutomaticDimension;

iOS7
(就让iOS7丢弃在历史中吧。)
ios中没有UITableViewAutomaticDimension自动计算高度,就只能自己去计算了。
ios7中需要一个辅助cell,cell的内容和UITableView的内容一致,但不用于显示,而是用于根据填充的内容计算每个cell的高度。

@property (strong,nonatomic) AdaptionCell *adaptionCell;
//-(void)viewDidLoad 这里为什么不能使用[tableView dequeueReusableCellWithIdentifier:cellIdentifier forIndexPath:indexPath]设置一个cell。因为这会导致cell被创建了但是又未曾被tableView:cellForRowAtIndexPath:方法返回,会造成内存泄露。
self.adaptionCell = [cellNib instantiateWithOwner:nil options:nil][0];
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
 self.adaptionCell.contentLabel.text=self.dataArray[indexPath.row%2];
    [self.adaptionCell layoutIfNeeded];
    CGFloat height = [self.adaptionCell.contentView systemLayoutSizeFittingSize:UILayoutFittingCompressedSize].height;
    return height+1;
}

这里为什么要+1,因为UITableViewCell有个边缘线,比其ContentView高1(其实应该是0.5)

上面的方法里使用的一个函数systemLayoutSizeFittingSize获取contentView的size,最终得到一个自适应后的height。

但这里有个问题---为什么这个方法得到了一个自适应的height,而不一个自适应的Width!
所以应该有个地方来限定Width,使得Cell的内容的填充是在纵向上,而不是横向。

//  AdaptionCell.m
- (void)layoutSubviews{
    [super layoutSubviews];
    [self.contentView layoutIfNeeded];
    self.contentLabel.preferredMaxLayoutWidth = CGRectGetWidth(self.contentLabel.frame);
}

LAST LAST

最后的最后,附上结果图:

Paste_Image.png

和一个问题:
如果cell中需要自适应高度的文本是富文本,是否还可以使用autolayout做自适应?
简单的UILabel attributedText可以通过

作者:Seas
链接:http://www.jianshu.com/p/386b792054b1
來源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

时间: 2024-11-05 16:29:58

UITableViewCell高度自适应的关键点的相关文章

uitableviewcell高度自适应笔记

今天看了几篇uitableviewcell高度自适应的文章,大体分为两种方式. 第一种方式,cell里面有label,在cellforrow绘制的时候计算Label的可能高度,并且在此时重新计算cell的高度,然后在heightforrow的时候返回这个cell新的高度.也就是说这些cell全部是计算出来的,根据里面的label的高度(label为contentView).http://blog.csdn.net/swingpyzf/article/details/18093959 第二种方式是

UITableViewCell 高度自适应

UITableViewCell 高度自适应一直是我们做动态Cell高度时遇到的最烦躁的问题,Cell动态高度计算可以去看看sunny的这篇文章介绍,今天主要和大家分享下我在使用systemLayoutSizeFittingSize系统自带方法计算高度的一些心得! Demo gif 先看原函数注释 /* The size fitting most closely to targetSize in which the receiver's subtree can be laid out while 

UITableViewCell 高度计算从混沌初始到天地交泰

[原创]UITableViewCell 高度计算从混沌初始到天地交泰 本文主要基予iOS UITableViewCell 高度自适应计算问题展开陈述,废话少说直入正题: UITableView控件可能是iOS中大家最常用的控件了(滚动视图.cell重用.卡顿优化),今天要讨论的不是这些高大上的话题,今天的话题只是cell高度的计算. * 传统frame布局下UITableViewCell 高度计算 * AutoLayout下UITableViewCell高度计算(iOS6.7) * UITabl

autolayout 高度自适应

https://lvwenhan.com/ios/449.html #import "ViewController.h" #import "MyTableViewCell.h" static NSString *cellIdentifier = @"mycell"; @interface ViewController () <UITableViewDelegate, UITableViewDataSource> @property (

UI_11 自定义UITableViewCell、Cell的高度自适应

UITableViewCell很难满足我们的需求,因此,CustomCell(自定义单元格)至关重要.下面将通过一个例子演示自定义Cell.第二部分演示根据文本内容自适应Label.Cell高度. 第一部分 CustomCell的创建 1.创建DemoTableViewController,继承自UITableViewController,并设置其为window的根视图 AppDelegate.m - (BOOL)application:(UIApplication *)application

AutoLayout五、使用Masonry完成UITableViewCell的自适应高度

第一步.Base TableViewController 封装tableView的 数据源方法.代理方法.这里只给出cell height的代理函数部分: - (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath { //不使用高度自适应的cell,返回其设置的默认高度 if (![[self cellClass] isDynamic]) { return [sel

iOS UITableView+FDTemplateLayoutCell 配合AutoLayout分分钟教你实现动态高度自适应

UITableView里面的Cell固定高度那是基本不可能了,很多功能和界面都会涉及到高度自适应,而且电商类的尤其普遍,之前都是自己算啊算,代码写的非常多,逻辑还没写,光这布局UI和高度计算都能接近1000了,写完之后关键出点Bug整个人都不好了 当时的是这样的: 突然在github上看到UITableView+FDTemplateLayoutCell这个库 传送门:点击打开链接 刚看到的时候是这样的: 能  用   么 ??? 真  的  这  么 叼 ??? 第一次用的时候是这样的: 哥们,

关于TableViewCell高度自适应问题的整理

TableViewCell高度自适应在网上有很多资料,我只想找出最最最简单的一种方法. 首先梳理一下思路.说到TableViewCell我们第一个想到的问题或许就是cell的复用问题. 1.  [self.tableView registerClass:[Cell class] forCellReuseIdentifier:str];注册之后可以在cell代理函数里调用 Cell *cell = [tableView dequeueReusableCellWithIdentifier:str f

tableviewheaderview&#160;高度自适应

完全使用约束 使tableviewheaderview 的高度自适应,以后再也不用去计算headerview的高度后再去改变高度了, demo代码: #import "ViewController.h" #import "Masonry.h" @interface ViewController ()<UITableViewDelegate,UITableViewDataSource> @end @implementation ViewController