IOS使用masonry布局Cell的一些坑

Masonry简介

Masonry是一个轻量级的布局框架,它拥有自己的描述语法(采用更优雅的链式语法封装)来自动布局,具有很好可读性且同时支持iOS和Max OS X等。总之,对于侧重写代码的coder,请你慢慢忘记Frame,喜欢Masonry吧

为什么使用Masonry

Masonry 出来也很有一段时间了,由于之前一直使用Frame方式布局(iOS7之前的程序员的痛),复杂的界面则使用MVVM模式来处理,与后来为了快速拉界面做屏幕适配而使用的xib的Autoresizing等布局方式。并未使用过这个第三方库,后来一直听说Masonry的“轻量,链式语法,高可读性等特点”,一副好像很厉害的样子,老夫实在是忍不住想要搞事情了。刚好有个不怎么复杂的界面就拿来试试手先。。。(哪知这一试竟试出来四十级电视连续剧的赶脚)

关于Masonry的一些东西

先说说一些Masonry的一些基础东西吧

常见约束的各种类型

/**

1.尺寸:width、height、size

2.边界:left、leading、right、trailing、top、bottom (leading、 trailing与left、right意义相同,一般使用后者)

3.中心点:center、centerX、centerY

4.边界:edges

5.偏移量:offset、insets、sizeOffset、centerOffset

6.priority()约束优先级(0~1000),multipler乘因数, dividedBy除因数

*/

常见约束的三种方法

/**

//这个方法只会添加新的约束

[view mas_makeConstraints:^(MASConstraintMaker *make)  {

}];

// 这个方法会将以前的所有约束删掉,添加新的约束

[view mas_remakeConstraints:^(MASConstraintMaker *make) {

}];

// 这个方法将会覆盖以前的某些特定的约束

[view mas_updateConstraints:^(MASConstraintMaker *make) {

}];

*/

tag : 看到block小伙伴们是不是下意识的想到使用 __weak typeof (self) weakSelf = self 来避免循环引用啊,很显然Masonry这么NB的框架怎么可能会出现这么低的撸点呢,笔者经过验证,Masonry内block是局部的引用,block内部引用self不会造成循环引用的,所以骚年们请放心大胆的使用self吧!

用法

这里就不多说了!大家可以自行的去找度娘和谷哥,它们不一定能给你更好,但一定能给你更多。。。

布局Cell的一些坑

笔者的需求是做出如下图的样式,其实这是一个很简单的页面布局,即没多层次的页面,也不用动态获取Cell的高度,用xib甚至几次拖拽就能搞定的东西,唯一动态的就是日期与头像之间的三个label,但就是这三个动态的label,却在我使用Masonry去实现的时候,让我一度痛苦不堪。。。(其实就是自己太水了)



做这个页面,头像view,时间view,底部的view与距离view由于实现的逻辑比较简单,这里就不过多的说了,主要说说上面的需要动态展示width,且需要展示优先级在左边,最初的实现思路是,姓名view的左边与头像view右边约束固定,顶部等同于头像view的顶部,大小使用sizeToFit;职务view 除了需要底部与姓名view约束相等外,其它的逻辑与姓名view与头像view之前的约束逻辑是一样的!大小同样使用sizeToFit,备注view的约束这里就是底部与职务view相等,且左边与职务view的右边设置约束,右边与时间view的左边设置约束。。。。(说的都是些啥玩意!废话一大堆,还是直接上代码吧)



Ctrl + R 等待界面效果。。。



肿么会是这样勒!我想要的不是这样,我选择拒绝,我选择狗带。然后默默的看了看周围的同事,但显然没人会甩我矫情,只能继续改代码。。。



这里改变之前的思路!至于之前的思路有什么问题!这里就不要深究了。其实我也表示一脸蒙B,这里通过sizeWithAttributes 方法提前获取前两个label的大小,动态的展示第三个label的宽度,且不能与时间label重叠,一运行!好像还是那么回事



爽到不行,竟然正常了,穿个滑板鞋来庆祝一下先,我滑!我滑!我滑!诶...等等,好像有哪里不对劲,当我滑动tabelView的时候,在返回来的时候竟然变成了这样,中间的label竟然展示不全了,<崩溃脸>



显然是cell重用问题!作为一个写了好几个月iOS界面代码的程序员,这能难到我!直接在model的set方法里使用mas_remakeConstraints 方法 重新需要动态布局的约束,代码如下


机智如我!果然,再次滑滑滑的时候,没有出现前面单元格复用而出现的label展示不全问题,这里是当向cell Set Model时,将前一约束删除,更新需要动态展示的视图,完美解决cell重用问题。

总结

暂时就这么多!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,236评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,867评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,715评论 0 340
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,899评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,895评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,733评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,085评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,722评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,025评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,696评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,816评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,447评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,057评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,009评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,254评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,204评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,561评论 2 343

推荐阅读更多精彩内容

  • Masonry是一个轻量级的布局框架,拥有自己的描述语法,采用更优雅的链式语法封装自动布局,简洁明了并具有高可读性...
    3dcc6cf93bb5阅读 1,753评论 0 1
  • (一)Masonry介绍 Masonry是一个轻量级的布局框架 拥有自己的描述语法 采用更优雅的链式语法封装自动布...
    木易林1阅读 2,315评论 0 3
  • 写在前面 iOS的的布局机制「auto layout」不是一个新概念,它早在iOS 6中就推出来了,当下距离iOS...
    西门淋雨阅读 1,508评论 2 4
  • 三月好想去伊人眼里踏青那里有两潭湖水两只新燕透明的岛上天使的柔翅忽闪我们和阳光嬉戏也和细雨交谈在风的怀抱里睡去醒来...
    伊甸陨石阅读 187评论 0 1
  • 《好好学习》读书笔记 成长是勇敢者的游戏 我们通常会看到一个的自大的人在成功时会认为是因为自己厉害,...
    泥石刘阅读 1,050评论 1 3