自大iOS8推出了tableview自适应高度,我就一直想试试,刚好手上有个新闻的app需要用到就尝试了下。

使用流程很多博客上都有提,在storyboard中拉一个cell然后把里面的元素都设置好约束。这个我常做,注意最后一个元素要设置到底部的约束。

在storyboard中我没有将 打上勾

然后结果就是这样的了

iPhone6p上一切正常:

iPhone5和iPhone6上tableview的高度自适应就没有成功:

 

如果我打上了这个勾

再来看下iPhone6p上:

iPhone5s或iPhone6上:

 

总结一下也就是说

 
preferred width yes    No
iPhone6p
 异常

正常
iPhone5s or iPhone6 正常 异常

当然 preferred width的大小也关系着页面是否正常。若设置的比屏幕宽度大,那么即便选中,在iPhone5s或者6上依旧是会出现问题。

综合一下我这边给出的解决方案是 

1.不选中

2.在自定义cell的awakeFromNib中添加以下代码。通过判断机型来适配自适应。

    if (SCREEN_WIDTH < 414) {
        CGFloat preMaxWaith =200;
        [self.commentLabel setPreferredMaxLayoutWidth:preMaxWaith];
    }