鏈?zhǔn)骄幊痰慕榻B與Masonry
首先看一下OC下使用優(yōu)秀第三方框架Masonry
在實(shí)現(xiàn)一個(gè)自動(dòng)布局時(shí)候的實(shí)現(xiàn)代碼:
[self.demoTextField mas_makeConstraints:^(MASConstraintMaker *make) {
make.top.equalTo(self.view).and.offset(100);
make.width.equalTo(self.view);
make.height.equalTo(@44);
}];
其中在對(duì)y位置添加約束的時(shí)候,使用了連續(xù)的.
語法。這就是鏈?zhǔn)骄幊獭?/p>
BabyBluetooth
Masonry中的鏈?zhǔn)娇赡芟鄬?duì)比較零散,并不能體現(xiàn)出鏈?zhǔn)降娜蝿?wù)邏輯連貫性。
下面介紹另外一個(gè)優(yōu)秀的第三方框架BabyBluetooth
,BabyBluetooh
是簡(jiǎn)單易用的藍(lán)牙庫(kù),基于CoreBluetooth的封裝,并兼容ios和mac osx。
CoreBluetooth所有方法都是通過委托完成,代碼冗余且順序凌亂。BabyBluetooth使用block方法,可以重新按照功能和順序組織代碼,并使用鏈?zhǔn)骄幊虒⒁唤M任務(wù)用一條鏈完成。
baby.having(self.currPeripheral).and.channel(channelOnPeropheralView).then.connectToPeripherals().discoverServices().discoverCharacteristics().readValueForCharacteristic().discoverDescriptorsForCharacteristic().readValueForDescriptors().begin();
用一條鏈就完成了一整套的連接peripheral,發(fā)現(xiàn)服務(wù),發(fā)現(xiàn)特性,讀取特性值,發(fā)現(xiàn)描述,讀取描述值的任務(wù)鏈,而不需要多次的分散調(diào)用,流程邏輯非常清晰。
開工
說了辣么多,那么到底怎么實(shí)現(xiàn)呢?
首先
我們都知道self.aString
其中的aString是個(gè)屬性,類型看樣子應(yīng)該是個(gè)正經(jīng)的NSString類型.
那么self.aString()
是個(gè)什么寫法呢,我們把aString
換個(gè)名字self.functionPointer()
。
好了,現(xiàn)在從名字可以看的出來這個(gè)functionPointer貌似是個(gè)函數(shù)指針,那么self.functionPointer
+()
也就代表調(diào)用函數(shù),如果這個(gè)函數(shù)有參數(shù)那么完整的調(diào)用應(yīng)該是這樣的self.functionPointer(@"testString");
。
但是這樣只能一次調(diào)用,并沒有實(shí)現(xiàn)鏈?zhǔn)降男Ч?br>
別急,假如我們的函數(shù)指針指向的函數(shù)是有返回類型的呢?并且,返回的類型就是self
的類型。那么,self.functionPointer(@"testString")
執(zhí)行完成后的結(jié)果就是self
,再用這個(gè)結(jié)果通過函數(shù)指針去調(diào)函數(shù),好了,鏈出來了。
self.functionPointer(@"firstString").functionPointer(@"secondString").functionPointer(@"thirdString");
大概的寫法是這樣的:
JCChainStyleManager.h文件
#import <Foundation/Foundation.h>
@class JCChainStyleManager;
typedef JCChainStyleManager* (*CLikeFunction) (NSString *);
@interface JCChainStyleManager : NSObject
#pragma mark - 用函數(shù)指針實(shí)現(xiàn)的鏈?zhǔn)?
- (CLikeFunction)dotMessageWithCFunction;
@end
JCChainStyleManager.m 文件
@implementation JCChainStyleManager
- (CLikeFunction)dotMessageWithCFunction{
return testFunction;
}
JCChainStyleManager *testFunction(NSString *aString){
NSLog(@"this is a C like function and log: %@",aString);
return [JCChainStyleManager new];
};
@end
調(diào)用處
JCChainStyleManager *chainManager = [JCChainStyleManager new];
chainManager.dotMessageWithCFunction(@"6666").dotMessageWithCFunction(@"999");
感覺用函數(shù)指針的方式來解釋更加的易懂,但是在實(shí)際使用的時(shí)候c函數(shù)并不能捕獲到到同一個(gè)self
對(duì)象,每次函數(shù)執(zhí)行完成要完成鏈?zhǔn)蕉家匦聞?chuàng)建一個(gè)self
對(duì)象,除非將self
做成單例的模式。
Block
介于使用函數(shù)指針的方式實(shí)在太逆天,而且需要要到c函數(shù),所以下面切換到常規(guī)的block
實(shí)現(xiàn)的方式。
JCChainStyleManager.h文件
@class JCChainStyleManager;
typedef JCChainStyleManager *(^JCChainVoidBlock)();
typedef JCChainStyleManager *(^JCChainStringBlock)(NSString *);
@interface JCChainStyleManager : NSObject
#pragma mark - 用block實(shí)現(xiàn)的鏈?zhǔn)?
- (JCChainVoidBlock)begin;
- (JCChainVoidBlock)firstBlock;
- (JCChainStringBlock)secondBlock;
@end
JCChainStyleManager.m 文件
@implementation JCChainStyleManager
- (JCChainVoidBlock)begin{
return ^JCChainStyleManager *() {
NSLog(@"begin");
return self;
};
}
- (JCChainVoidBlock)firstBlock{
return ^JCChainStyleManager *() {
NSLog(@"聽局座唱rap??,看諸葛琴魔");
return self;
};
}
- (JCChainStringBlock)secondBlock{
return ^JCChainStyleManager *(NSString * aString) {
NSLog(@"%@",aString);
return self;
};
}
@end
調(diào)用處
JCChainStyleManager *chainManager = [JCChainStyleManager new];
chainManager.firstBlock().secondBlock(@"asd").begin();
當(dāng)執(zhí)行chainManager.firstBlock
的時(shí)候,實(shí)際是使用了getter
方法,并獲取到了類型為JCChainVoidBlock的塊,然后使用chainManager.firstBlock
+()
的方式執(zhí)行了代碼塊,并且返回了self
,以調(diào)用下個(gè)鏈節(jié)點(diǎn)。