Masonry 与 frame 混用导致的问题
https://www.jianshu.com/p/357fab4b84e7
Masonry 与 frame 混用可能出现子控件大小跟预期不一致的情况,具体是什么样呢?
例如,自定义一个 UIView 的子类SmallView,SmallView 中含有一个 UIImageView,在控制器创建SmallView,在SmallView创建UIImageView时都使用 init 方法,都没有给定 frame,但是在使用 masonry 约束时,用到了 frame,那么这就很可能会出现问题,导致大小跟预期不一致。
一.
在 SmallView 中创建 UIImageView
_imageView = [[UIImageView alloc] init];
_imageView.image = [UIImage imageNamed:@"一无所有"];
[self addSubview:_imageView];
//1.
//这种写法容易出问题,如果 SmallView 创建时没有设置 frame 或者重新约束,那么_imageView并不能达到预期的效果
//SmallView init 会先执行这里,然后在约束SmallView,但是 imageview 的大小已经在这里定型了
[_imageView mas_makeConstraints:^(MASConstraintMaker *make) {
//问题就在self.bounds.size.width,self.bounds.size.height,如果外面创建SmallView时,没有 frame, 这里就是0了
make.size.mas_equalTo(CGSizeMake(self.bounds.size.width, self.bounds.size.height));
make.center.mas_equalTo(self);
}];
在控制器中创建 SmallView
//1.没有给定 frame,此时 SmallView的imageView 已经大小为0了
SmallView *small = [[SmallView alloc] init];
[self.view addSubview:small];
//约束和 frame 不一致,SmallView的imageView 已经大小为0了,只对SmallView起效果了
[small mas_makeConstraints:^(MASConstraintMaker *make) {
make.size.mas_equalTo(CGSizeMake(100, 100));
make.top.mas_equalTo(self.view).mas_offset(30);
make.leading.mas_equalTo(self.view).mas_offset(30);
}];
结果是这样,没有大小,不是与 SmallView 一样大

imageView 大小为0.png
那就给一个 frame
SmallView *small = [[SmallView alloc] initWithFrame:CGRectMake(0, 0, 50, 50)];
图片大小为 init 时的50,50

image 并没有跟 SmallView 一样大.png
那么正确的姿势来了。
二.
在 SmallView 中创建 UIImageView
//2.
//这种写法无论 SmallView在创建时有没有给定 frame 或者给了 frame 但是约束跟 frame 不一致也不会出问题.
[_imageView mas_makeConstraints:^(MASConstraintMaker *make) {
//这里是约束,并不是 frame
//make.size.mas_equalTo(self);
make.width.mas_equalTo(self.mas_width);
make.height.mas_equalTo(self.mas_height);
make.center.mas_equalTo(self);
}];
在控制器中创建 SmallView
//2.frame 和约束不一致,使用的是约束,无所谓啦
//SmallView *small = [[SmallView alloc] init];
SmallView *small = [[SmallView alloc] initWithFrame:CGRectMake(0, 0, 50, 50)];
[self.view addSubview:small];
//约束和 frame 不一致,使用的是约束,无所谓啦
[small mas_makeConstraints:^(MASConstraintMaker *make) {
make.size.mas_equalTo(CGSizeMake(100, 100));
make.top.mas_equalTo(self.view).mas_offset(30);
make.leading.mas_equalTo(self.view).mas_offset(30);
}];

不怕不怕啦.png
那么,结论就是在自定义控件时,内部约束尽量使用mas_width这种属性,谨慎使用具体数值,如固定的 width 等等。如果你使用了 UIView 的快速改变 frame 的分类一定要注意,很多属性名类似,如 centerX 与mas_centerX可是不一样的,后果你遇到就知道啦~
代码https://github.com/lxszl/UIViewTest
作者:loyt
链接:https://www.jianshu.com/p/357fab4b84e7
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。
Masonry 与 frame 混用导致的问题的更多相关文章
- npm与cnpm混用导致的问题
npm和cnpm混用之后,再用npm升级模块导致如下错误: 解决办法: 删除node_modules文件下的文件后,重新执行npm install
- 静态链接和动态链接库混用导致的链接错误LINK2005
对于一个静态链接库L.lib,它的使用者app.exe会静态链接L.lib,意思是app.exe会将L.lib中的代码(app需要的部分,例如函数定义,类的定义等等)链接到app.exe中. 而对 ...
- titleView发生偏移、titleView与masonry、titleView的设置、titleView的使用
navigationItem的titleView属性的设置本身是很简单的,容易出问题的原因是自动化布局与frame混用造成的. 本文一步一步的讲解,力求找到问题的起源.如果你也在这块同样遇到问题,不妨 ...
- Selenium2学习-008-WebUI自动化实战实例-006-易迅登录之 frame 处理
此文主要讲述用 Java 编写 Selenium 自动化测试脚本编写过程中,在因 frame 标签导致页面定位失败,提示 NoSuchElementException 时的,页面元素定位前的 fram ...
- 《从陷阱中学习C/C++》读书笔记
1.运算符优先级很容易引起问题,如a = 4<<1+1,由于<<的优先级低于+,故其执行过程为 a = 4<<(1+1); 常见的运算符优先关系:(具体参照博客) ...
- Requests库上传文件时UnicodeDecodeError: 'ascii' codec can't decode byte错误解析
在使用Request上传文件的时候碰到如下错误提示: 2013-12-20 20:51:09,235 __main__ ERROR 'ascii' codec can't decode byte 0x ...
- C/C++走过的坑(基础问题篇)
1.有符号int与无符号int比较 #define TOTOL_ELEMENTS (sizeof(a) / sizeof(a[0]) ); int main() { int a[] = {23,24, ...
- 201521123076 《Java程序设计》第10周学习总结
1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常与多线程相关内容. 创建线程方式: 定义Thread的子类,覆盖run(),之后创建实例.因为开销大,一般不用. 定义实现Run ...
- 201521123030 《Java程序设计》 第10周学习总结
1. 本周学习总结 2. 书面作业 本次PTA作业题集异常.多线程 1.finally 题目4-2 1.1 截图你的提交结果(出现学号) 1.2 4-2中finally中捕获异常需要注意什么? 在fi ...
随机推荐
- C#___.net经典题
1 请你说说 .NET 中类和结构的区别? 答:结构和类具有大体的语法,但是结构受到的限制比类要多.结构不能申明有默认的构造函数,为结构的副本是又编译器创建 和销毁的,所以不需要默认的构造函数和 ...
- "每日一道面试题".net托管堆是否会存在内存泄漏的情况
首先说答案:会 所谓的内存泄漏,就是指内存空间上产生了不再被实际使用却又无非被分配的对象.严格意义上来说,在.net中经常会遇到内存泄漏的情况,因为托管堆内的对象不再被使用时,需要等待下一次GC才会被 ...
- C# Word文档中插入、提取图片,文字替换图片
Download Files:ImageOperationsInWord.zip 简介 在这篇文章中我们可以学到在C#程序中使用一个Word文档对图像的各种操作.图像会比阅读文字更有吸引力,而且图像是 ...
- input type date 解决移动端显示placeholder
在最近的一个项目中使用到了html5的一个新标签属性,type="date"时,发现placeholder属性失效无法使用. 如果是这样的效果,那么客户体验是可想而知的差了. 最后 ...
- jQuery 嵌套 event 会触发多次的原因
Html代码如下: <div id="cover"> <input type="button" id="inside" v ...
- 前端入门13-JavaScript进阶之原型
声明 本系列文章内容全部梳理自以下几个来源: <JavaScript权威指南> MDN web docs Github:smyhvae/web Github:goddyZhao/Trans ...
- eclipse配置freemarker,*.ftl文件
亲测,提供2种方式,效果都不错: ----------------------------------------- 1.直接下载相应的插件.只需要下载FreeMarker的识别Jar包就可以:888 ...
- ArcGIS Server注册数据库——以oracle为例
原创文章,转载须标明出处自: https://www.cnblogs.com/gisspace/p/9089117.html ------------------------------------- ...
- Java新知识系列 四
[]URL的组成<协议>://<主机>:<端口>/<路径> . []线程的定义实例化和启动. []类的final变量初始化需要满足的条件. []管道通信 ...
- MySQL 基础知识梳理学习(二)----记录在页面层级的组织管理
1.InnoDB的数据存储结构 InnoDB中数据是通过段.簇.页面构成的. (1)段是表空间文件中的主要组织结构,它是一个逻辑概念,用来管理物理文件,是构成索引.表.回滚段的基本元素.创建一个索引( ...