深入理解IOS控件布局之Masonry布局框架

发布时间 - 2026-01-10 23:01:45    点击率:

前言:

回想起2013年做iOS开发的时候,那时候并没有采用手写布局代码的方式,而是采用xib文件来编写,如果使用纯代码方式是基于window的size(320,480)计算出一个相对位置进行布局,那个时候windows的size是固定不变的,随着iphone5的发布,windows的size(320,568)也发生了变化,而采用autoresizingMask的方式进行适配,到后来iphone 6之后windows size的宽度也随之变化,开始抛弃autoresizingMask改用autolayout了,使用autolayout进行适配我也是最近重新做iOS开发才接触的,公司使用Masonry框架进行布局适配。所以学习使用这个布局框架对我来说至关重要,它大大提高了开发效率而且最近使用起来很多语法和Android有很大的相似之处。

什么是Masonry?

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

如何使用?

1.)引入头文件

我这里是在全局引用pch文件中引用的

#import "Masonry.h"

2.)基本语法

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;//文本基线

Masonry提供了三个函数方法

  • - (NSArray *)mas_makeConstraints:(void(^)(MASConstraintMaker *make))block; //新增约束
  • - (NSArray *)mas_updateConstraints:(void(^)(MASConstraintMaker *make))block;//更新约束
  • - (NSArray *)mas_remakeConstraints:(void(^)(MASConstraintMaker *make))block;//清楚之前的所有约束,只会保留最新的约束

我们根据不同的使用场景来选择使用不同的函数方法。

3.)具体举例

  比如一个往父控件中添加一个上下左右与父控件间距为50的子视图

添加约束

  UIView *tempView=[[UIView alloc]init];
  tempView.backgroundColor=[UIColor greenColor];
  [self.view addSubview:tempView];
  
  [tempView mas_makeConstraints:^(MASConstraintMaker *make) {
    make.left.mas_equalTo(50);
    make.right.mas_equalTo(-50);
    make.top.mas_equalTo(50);
    make.bottom.mas_equalTo(-50);
  }];

等价于

  UIView *tempView=[[UIView alloc]init];
  tempView.backgroundColor=[UIColor greenColor];
  [self.view addSubview:tempView];
  
  [tempView mas_makeConstraints:^(MASConstraintMaker *make) {
    make.left.equalTo(self.view.mas_left).offset(50);
    make.right.equalTo(self.view.mas_right).offset(-50);
    make.top.equalTo(self.view.mas_top).offset(50);
    make.bottom.equalTo(self.view.mas_bottom).offset(-50);
  }];

也可以简化为下面这种

  UIView *tempView=[[UIView alloc]init];
  tempView.backgroundColor=[UIColor greenColor];
  [self.view addSubview:tempView];
  
  [tempView mas_makeConstraints:^(MASConstraintMaker *make) {
    make.edges.mas_equalTo(UIEdgeInsetsMake(50, 50, 50, 50));
  }];

又等价于

  UIView *tempView=[[UIView alloc]init];
  tempView.backgroundColor=[UIColor greenColor];
  [self.view addSubview:tempView];
  
  [tempView mas_makeConstraints:^(MASConstraintMaker *make) {
    make.edges.equalTo(self.view).insets(UIEdgeInsetsMake(50, 50, 50, 50));
  }];

更新约束

  [tempView mas_updateConstraints:^(MASConstraintMaker *make) {
    make.left.mas_equalTo(50);
    make.right.mas_equalTo(-50);
    make.top.mas_equalTo(100);
    make.bottom.mas_equalTo(-100);
  }];

清除之前的约束保留最新的

  [tempView mas_remakeConstraints:^(MASConstraintMaker *make) {
    make.left.mas_equalTo(100);
    make.right.mas_equalTo(-100);
    make.top.mas_equalTo(100);
    make.bottom.mas_equalTo(-100);
  }];

特别注意:

声明约束必须在视图添加到父试图上面之后调用。

4.)mas_equalTo与equalTo

上面的举例中分别使用了mas_equalTo和equalTo达到了同样的效果,我在刚开始使用Masonry的时候很容易混淆他们两个,今天特意分析一下他们的区别。mas_equalTo是一个MACRO,比较的是值,equalTo比较的是id类型。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# ios  # 自动布局  # masonry  # masonry布局  # 布局  # iOS界面布局简化UIStackView使用详解  # iOS布局渲染之UIView方法的调用时机详解  # 详解iOS自定义UITabBar与布局  # iOS ScrollView实现自动布局的方法(适用Swift 3.0 )  # IOS xib布局小技巧-边框设置  # iOS开发Masonry与Frame布局差异示例详解  # 的是  # 是一个  # 链式  # 自己的  # 他们的  # 是在  # 我在  # 之处  # 很容易  # 只会  # 上下左右  # 达到了  # 那时候  # 刚开始  # 对我来说  # 回想起  # 至关重要  # 如何使用  # 使用这个  # 首部 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现API资源集合?(Resource Collection教程)  Java类加载基本过程详细介绍  香港服务器网站推广:SEO优化与外贸独立站搭建策略  如何解决hover在ie6中的兼容性问题  奇安信“盘古石”团队突破 iOS 26.1 提权  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  如何快速生成高效建站系统源代码?  javascript中闭包概念与用法深入理解  如何快速上传自定义模板至建站之星?  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  EditPlus 正则表达式 实战(3)  javascript如何操作浏览器历史记录_怎样实现无刷新导航  Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  使用Dockerfile构建java web环境  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  Laravel怎么实现微信登录_Laravel Socialite第三方登录集成  Laravel如何实现图片防盗链功能_Laravel中间件验证Referer来源请求【方案】  如何在阿里云ECS服务器部署织梦CMS网站?  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  Laravel如何使用Service Container和依赖注入?(代码示例)  如何获取免费开源的自助建站系统源码?  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】  高性价比服务器租赁——企业级配置与24小时运维服务  Laravel如何使用Blade组件和插槽?(Component代码示例)  Laravel怎么配置.env环境变量_Laravel生产环境敏感数据保护与读取【方法】  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  Laravel如何保护应用免受CSRF攻击?(原理和示例)  独立制作一个网站多少钱,建立网站需要花多少钱?  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤  微博html5版本怎么弄发语音微博_语音录制入口及时长限制操作【教程】  公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?  免费视频制作网站,更新又快又好的免费电影网站?  Internet Explorer官网直接进入 IE浏览器在线体验版网址  详解Android——蓝牙技术 带你实现终端间数据传输  Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践  Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】  百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  Firefox Developer Edition开发者版本入口  EditPlus中的正则表达式 实战(4)