全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

前言:

回想起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布局差异示例详解  # 的是  # 是一个  # 链式  # 自己的  # 他们的  # 是在  # 我在  # 之处  # 很容易  # 只会  # 上下左右  # 达到了  # 那时候  # 刚开始  # 对我来说  # 回想起  # 至关重要  # 如何使用  # 使用这个  # 首部 


相关文章: 英语简历制作免费网站推荐,如何将简历翻译成英文?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  网站制作的方法有哪些,如何将自己制作的网站发布到网上?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  定制建站如何定义?其核心优势是什么?  定制建站策划方案_专业建站与网站建设方案一站式指南  如何通过商城自助建站源码实现零基础高效建站?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  高性价比服务器租赁——企业级配置与24小时运维服务  兔展官网 在线制作,怎样制作微信请帖?  如何选择最佳自助建站系统?快速指南解析优劣  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  ,巨量百应是干嘛的?  如何选择域名并搭建高效网站?  测试制作网站有哪些,测试性取向的权威测试或者网站?  七夕网站制作视频,七夕大促活动怎么报名?  如何快速生成ASP一键建站模板并优化安全性?  济南网站制作的价格,历城一职专官方网站?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  建站之星在线客服如何快速接入解答?  广州营销型建站服务商推荐:技术优势与SEO优化解析  如何快速搭建高效香港服务器网站?  家庭建站与云服务器建站,如何选择更优?  清除minerd进程的简单方法  深入理解Android中的xmlns:tools属性  如何在企业微信快速生成手机电脑官网?  武汉外贸网站制作公司,现在武汉外贸前景怎么样啊?  宝塔建站助手安装配置与建站模板使用全流程解析  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  如何将凡科建站内容保存为本地文件?  如何通过二级域名建站提升品牌影响力?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  网站制作公司排行榜,四大门户网站排名?  如何批量查询域名的建站时间记录?  湖北网站制作公司有哪些,湖北清能集团官网?  制作网页的网站有哪些,电脑上怎么做网页?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  如何制作网站标识牌,动态网站如何制作(教程)?  如何快速搭建虚拟主机网站?新手必看指南  如何通过远程VPS快速搭建个人网站?  网站制作知乎推荐,想做自己的网站用什么工具比较好?  教育培训网站制作流程,请问edu教育网站的域名怎么申请?  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  子杰智能建站系统|零代码开发与AI生成SEO优化指南  网站制作模板下载什么软件,ppt模板免费下载网站?  制作旅游网站html,怎样注册旅游网站?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一) 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。