Masonry 添加约束要注意顺序

Posted 琼'

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Masonry 添加约束要注意顺序相关的知识,希望对你有一定的参考价值。

对一个视图添加约束,其依赖的约束必须先已经存在,不能依赖该代码后的约束,否则造成不可预料的结果,如下代码能达到预期效果

- (void)makeConstraints {
    __weak typeof(self) weakSelf = self;

    [self.photoMoreButton mas_makeConstraints:^(MASConstraintMaker *make) {
        make.right.equalTo(weakSelf.photoButton).with.offset(-6);
        make.centerY.equalTo(weakSelf.photoButton);
        make.width.and.height.equalTo(@16);
    }];
    
    [self.photoImageView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.centerY.equalTo(weakSelf.photoButton);
        make.right.equalTo(weakSelf.photoMoreButton.mas_left);
        make.width.and.height.equalTo(@64);
    }];
}

但是如果颠倒添加约束的顺序,如下

- (void)makeConstraints {
    __weak typeof(self) weakSelf = self;
 
    [self.photoImageView mas_makeConstraints:^(MASConstraintMaker *make) {
        make.centerY.equalTo(weakSelf.photoButton);
        make.right.equalTo(weakSelf.photoMoreButton.mas_left);
        make.width.and.height.equalTo(@64);
    }];

     [self.photoMoreButton mas_makeConstraints:^(MASConstraintMaker *make) {
        make.right.equalTo(weakSelf.photoButton).with.offset(-6);
        make.centerY.equalTo(weakSelf.photoButton);
        make.width.and.height.equalTo(@16);
    }];
}

则得到的效果如下图

添加约束时 photoImageView 依赖于 photoMoreButton,而当时 photoMoreButton 的约束还未设置,所以导致后面不正确的结果,使用Masonry时要注意这点!

以上是关于Masonry 添加约束要注意顺序的主要内容,如果未能解决你的问题,请参考以下文章

Masonry使用注意事项

iOS代码约束处理&&Masonry源码分析

Masonry的简单实用(使用心得)

控件利用Masonry添加约束之后 不能立刻获取到该控件的尺寸

【Masonry】详解以及三种约束方法与注意事项

原iOS学习之Masonry第三方约束