iOS Masonry(约束)的基本使用

一、简介

Masonry是一个轻量级的布局框架 拥有自己的描述语法 采用更优雅的链式语法封装自动布局 简洁明了 并具有高可读性 而且同时支持 iOS 和 Max OS X。

Masonry支持的一些属性

//左侧
@property (nonatomic, strong, readonly) MASConstraint *left;
//上侧
@property (nonatomic, strong, readonly) MASConstraint *top;
//右侧
@property (nonatomic, strong, readonly) MASConstraint *right;
//下侧
@property (nonatomic, strong, readonly) MASConstraint *bottom;
//顶部
@property (nonatomic, strong, readonly) MASConstraint *leading;
//底部
@property (nonatomic, strong, readonly) MASConstraint *trailing;
//宽
@property (nonatomic, strong, readonly) MASConstraint *width;
//高
@property (nonatomic, strong, readonly) MASConstraint *height;
//横向中点
@property (nonatomic, strong, readonly) MASConstraint *centerX;
//纵向中点
@property (nonatomic, strong, readonly) MASConstraint *centerY;
//文本基线
@property (nonatomic, strong, readonly) MASConstraint *baseline;

二、基本使用

1、创建一个坐标为(100,100),宽度100,高度100的view:

    UIView *view = [UIView new];
    view.backgroundColor = [UIColor orangeColor];
    [self.view addSubview:view];
    //在做autoLayout之前 一定要先将view添加到superview上 否则会报错

    [view mas_makeConstraints:^(MASConstraintMaker *make) {
        make.left.equalTo(@100);
        make.top.equalTo(@100);
        make.width.equalTo(@100);
        make.height.equalTo(@100);
    }];

2、创建一个位于屏幕中央,宽度100,高度100的view:

    UIView *view = [UIView new];
    view.backgroundColor = [UIColor orangeColor];
    [self.view addSubview:view];

    [view mas_makeConstraints:^(MASConstraintMaker *make) {
        make.width.equalTo(@100);
        make.height.equalTo(@100);
        make.center.mas_equalTo(view.center);
    }];

3、创建一个与屏幕四边间隔都为10的view:

    UIView *view = [UIView new];
    view.backgroundColor = [UIColor orangeColor];
    [self.view addSubview:view];

    [view mas_makeConstraints:^(MASConstraintMaker *make) {
        make.edges.equalTo(self.view).with.insets(UIEdgeInsetsMake(10, 10, 10, 10));
    }];

三、特别说明

在Masonry中能够添加autolayout约束有三个函数

- (NSArray *)mas_makeConstraints:(void(^)(MASConstraintMaker *make))block;
- (NSArray *)mas_updateConstraints:(void(^)(MASConstraintMaker *make))block;
- (NSArray *)mas_remakeConstraints:(void(^)(MASConstraintMaker *make))block;
/*
mas_makeConstraints 只负责新增约束 Autolayout不能同时存在两条针对于同一对象的约束 否则会报错 
mas_updateConstraints 针对上面的情况 会更新在block中出现的约束 不会导致出现两个相同约束的情况
mas_remakeConstraints 则会清除之前的所有约束 仅保留最新的约束
三种函数善加利用 就可以应对各种情况了
*/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

长沙火山

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值