Masonry是一个轻量级的布局框架 拥有自己的描述语法 采用更优雅的链式语法封装自动布局 简洁明了 并具有高可读性 而且同时支持 iOS 和 Max OS X。 Masonry是一个用代码写iOS或os界面的库,可以代替Auto layout。
Masonry通过使用链式语法,使得代码简单易读,看下面代码:
make.top.equalTo(superview.mas_top).with.offset(10); //上面等于父视图的顶部,并且间隔为10
OC中实现链式语法的关键是block
,block具有一个函数的外观,又被当作一个变量。那么block就具备两个功能
第一:可以作为类的属性被'点'出来。
第二:可以当作函数直接调用。
注意:要求block必须有个返回值才能进行链式调用。
typedef SDAutoLayoutModel *(^MarginToView)(UIView *toView, CGFloat value); //返回值是SDAutoLayoutModel类型
/** 左边到其参照view之间的间距,参数为“(View, CGFloat)” */
@property (nonatomic, copy, readonly) MarginToView leftSpaceToView;
- (MarginToView)leftSpaceToView
{
if (!_leftSpaceToView) {
_leftSpaceToView = [self marginToViewblockWithKey:@"left"];
}
return _leftSpaceToView;
}
//调用实现
self.progressView.sd_layout
.leftSpaceToView(self.view, 0); //左边距等于view
发现如果一个类方法有返回值那么可以通过点---“.”来调用。
如下:
@implementation CLASS1
- (CLASS1 *) test{
NSLog(@"test 链式调用");
return self;
}
- (CLASS1 *) test2{
NSLog(@"call function OK ");
return self;
}
- (void) test3{
NSLog(@"over");
}
- (void)viewDidLoad {
[super viewDidLoad];
// [self test];
[self.test.test2 test3];
}
/**********
输出:
test 链式调用
call function OK
over
**********/
扩展:
Masonry的使用