使用masonry的一个坑
2018-12-14 本文已影响0人
地上的
总结 :在tableview等可复用cell的视图中,在cell上使用masonry进行约束时,如果是绝对参数,则需要进行remake而不是make来进行约束设置。如果使用相对参数进行布局则没问题。
示例:
有一个tableview
,上面有cell
,cell
上面有一个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);
}];