使用masonry的一个坑

2018-12-14  本文已影响0人  地上的

总结 :在tableview等可复用cell的视图中,在cell上使用masonry进行约束时,如果是绝对参数,则需要进行remake而不是make来进行约束设置。如果使用相对参数进行布局则没问题。

示例:
有一个tableview,上面有cellcell上面有一个UILabel,这个UILabel的高度height是由数据源中计算得来,那么在处理数据源的方法

- (void)configCellWithModel:(GHHomePageRelationSuggestDetailModel *)model {
}

中做这个UILabel的约束时如果采用相对约束:

[_descLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.equalTo(self.contentView).offset(16);
        make.right.equalTo(self.contentView).offset(-16);
        make.top.equalTo(self.backImageView.mas_bottom).offset(9);
        make.bottom.equalTo(self.contentView).offset(19);
    }];

则没有问题。

如果采用绝对约束:即直接设置高度,而不是设置底部对齐:

[_descLabel mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.equalTo(self.contentView).offset(16);
        make.right.equalTo(self.contentView).offset(-16);
        make.top.equalTo(self.backImageView.mas_bottom).offset(9);
        make.height.mas_equalTo(model.descSize.height);
    }];

这样由于cell的复用性,在下一次复用这个cell的时候,masonry不会再去重新设置这个height,但是height又由于数据源不一样而需要改变,就导致了显示错误。此时将mas_makeConstraints的方式改为mas_remakeConstraints的方式即可:

[_descLabel mas_remakeConstraints:^(MASConstraintMaker *make) {
        make.left.equalTo(self.contentView).offset(16);
        make.right.equalTo(self.contentView).offset(-16);
        make.top.equalTo(self.backImageView.mas_bottom).offset(9);
        make.height.mas_equalTo(model.descSize.height);
    }];
上一篇下一篇

猜你喜欢

热点阅读