记录一个因为使用masonry 布局造成的宽度不准确的问题

问题表现

如图,label 超出了cell的范围,明显的,计算出来的文字高度没有
label真实高度大
请添加图片描述

代码

添加约束使用masonry, 计算高度使用的是frame

///label 约束
    [self.answerContentLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.mas_equalTo(57 * rectScale());
        make.top.mas_equalTo(52 * rectScale());
        make.width.mas_equalTo(ScreenWidth - 72 * rectScale() - 33 * rectScale())
        ;
    }];

//计算高度
    [self.answerContentLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.mas_equalTo(57 * rectScale());
        make.top.mas_equalTo(52 * rectScale());
        make.width.mas_equalTo(ScreenWidth - 72 * rectScale() - 33 * rectScale())
        ;
    }];

检查

我们发现
如果修改成如下使用frame 添加布局,就会没有问题

        _answerContentLabel = [[UILabel alloc] initWithFrame:CGRectMake(57 * rectScale(), 52 * rectScale(), ScreenWidth - 72 * rectScale() - 33 * rectScale(), 0)];

使用图层分别查看label的 信息,发现虽然使用masonry 和 frame
设置的宽度是同样的值,但是真实绘制的label 宽度并不想等

在这里插入图片描述
在这里插入图片描述

启示

如果我们使用sizeThatFits的方式计算label内容的高度,则我们的label
布局的时候也要使用frame,否则可能会因为使用masonry布局导致
实际绘制的宽度和计算高度使用的宽度并不想等

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值