在运用Masonry的时候,经常遇到如下的语法:
make.top.mas_equalTo().mas_offset(),这就是大家所说的链式编程。
我们用block作为方法返回值实现:
定义Person类 继承NSObject,实现如下代码:
- (void(^)(NSString*))run
{
return ^(NSString *string){
NSLog(@"%@",string);
};
}
-(void(^)(NSString*))getUp
{
return ^(NSString *string){
NSLog(@"%@",string);
};
}
-(void(^)(NSString*))study
{
return ^(NSString *string){
NSLog(@"%@",string);
};
}
复制代码
在controller调用:
Person *p = [[Person alloc]init];
p.getUp(@"6点开始起床");
p.run(@"7点开始跑步");
p.study(@"8点开始学习");
复制代码
打印如下:
2019-04-30 12:57:22.959705+0800 RepeatUnit_iOS[6272:148869] 6点开始起床
2019-04-30 12:57:22.959969+0800 RepeatUnit_iOS[6272:148869] 7点开始跑步
2019-04-30 12:57:22.960376+0800 RepeatUnit_iOS[6272:148869] 8点开始学习
复制代码
我们成功实现了点语法调用、需要连续调用还得继续优化。p.getUp返回的是一个block,执行这个block 就是p.getUp()即为block的返回结果。连续点语法就得block返回为p(就是self),才能继续调用。修改如下:
- (Person*(^)(NSString*))run
{
Person*(^runBlock)(NSString *) = ^(NSString *string){
NSLog(@"%@",string);
return self;
};
return runBlock;
}
-(Person*(^)(NSString*))getUp
{
Person*(^getUpBlock)(NSString *) = ^(NSString *string){
NSLog(@"%@",string);
return self;
};
return getUpBlock;
}
-(Person*(^)(NSString*))study
{
Person*(^studyBlock)(NSString *) = ^(NSString *string){
NSLog(@"%@",string);
return self;
};
return studyBlock;
}
复制代码
控制器现在可以这样调用:
Person *p = [[Person alloc]init];
p.getUp(@"6点开始起床").run(@"7点开始跑步").study(@"8点开始学习");
复制代码
再次进行简单分析如下图:
- (Person*(^)(NSString*))run
{
Person*(^runBlock)(NSString *) = ^(NSString *string){
NSLog(@"%@",string);
return self;
};
return runBlock;
}
p.run 返回的是一个block 对应Person*(^)(NSString*)
p.run() 是runBlock的执行结果、如果我们让他返回为self、即可可以连续调用
复制代码