一. 框架的導入
這里推薦使用cocoa pods,管理起來比較方便。
(1)安裝 pods之后項目目錄下新建Podfile文件,文件內(nèi)容??
platform:'ios', '8.0'
target 'RWReactivePlayground' do
use_frameworks!
pod 'ReactiveCocoa'
end
(2)在Build Setting中將EMBEDDED_CONTENT_CONTAINS_SWIFT
設置為YES
此時ReactiveCocoa已經(jīng)導入成功!!!
二. 簡單使用
在需要使用的頁面中引入
#import <ReactiveCocoa/ReactiveCocoa.h>
(1)rac_textSignal 塊
此方法是針對于TextField的監(jiān)聽,基本可省略各種輸入框的delegate的方法。
例:
_textfild=[[UITextField alloc]initWithFrame:CGRectMake(20, 100, 100, 40)];
_textfild.placeholder=@"請輸入";
[self.view addSubview:_textfild];
[[_textfild rac_textSignal] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
打印出來的x的值就是textfield的輸入內(nèi)容,并且每輸入一次就會調(diào)用一次
而且如果有這種情況,在輸入密碼的時候,你只想在密碼超過六位以后才關注他是否正確可以這樣
例:
[[_textfild.rac_textSignal
filter:^BOOL(id value){
NSString*text = value;
return text.length > 6;
}]
subscribeNext:^(id x){
NSLog(@"%@", x);
}];
還有一種情況,我們只想關注用戶輸入了多少個字節(jié),不想關注他的內(nèi)容,這時候我們可以通過map
塊來改變事件的數(shù)據(jù)
例:
[[[_textfild.rac_textSignal
map:^id(NSString*text){
return @(text.length);
}]
filter:^BOOL(NSNumber*length){
return[length integerValue] > 6;
}]
subscribeNext:^(id x){
NSLog(@"%@", x);
}];
這時候你會發(fā)現(xiàn),只有在輸入框的字數(shù)超過六以后才會輸出,并且只是輸入字數(shù)。
(2)rac_signalForControlEvents監(jiān)聽方法,代替addTarget
如題,此block可以監(jiān)聽類似于textField button等的點擊方法。
例:
[[_textfild rac_signalForControlEvents:UIControlEventEditingChanged]
subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
[[_button rac_signalForControlEvents:UIControlEventTouchUpInside]
subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
(3)rac_signalForSelector代替代理事件
使用這個block需要傳入兩個參數(shù),需要執(zhí)行的方法名和需要遵守的協(xié)議,比如一個也 main需要多個alertview,如果使用代理的話,需要用tag判斷是哪個alert,點擊的是哪一個按鈕,代碼會非常繁瑣,此時使用RAC,看效果??
例:
UIAlertView * alertview=[[UIAlertView alloc]initWithTitle:@"RAC" message:@"RAC TE$XT" delegate:self cancelButtonTitle:@"queding" otherButtonTitles:@"quxaio", nil];
[[self rac_signalForSelector:@selector(alertView:clickedButtonAtIndex:) fromProtocol:@protocol(UIAlertViewDelegate)] subscribeNext:^(RACTuple *tuple) {
NSLog(@"000000===%@",tuple.first);
NSLog(@"111111===%@",tuple.second);
}];
[alertview show];
//監(jiān)聽點擊的是哪一個按鈕
[[alertview rac_buttonClickedSignal] subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
此時點擊alert的按鈕可以發(fā)現(xiàn),點擊“確定”就會輸出“00000”,點擊另外一個同理,下面的block監(jiān)聽點擊事件,輕松解決?。。?/p>
(4)ac_addObserverForName監(jiān)聽通知
這個使用起來就更簡單了,注冊通知正常寫,在接收通知的時候
例:
[[[NSNotificationCenter defaultCenter] rac_addObserverForName:@"postData" object:nil] subscribeNext:^(NSNotification *notification) {
NSLog(@"%@",notification.name);
NSLog(@"%@",notification.object);
}];
通過打印可以知道 notification.name是通知名 notification.object是傳入值,還是比較方便的,畢竟RAC的宗旨就是減少代碼量。
(5)RAC的宏定義監(jiān)聽對象屬性,代替KVO
KVO就不用多說了,監(jiān)聽,接受監(jiān)聽的方法,注銷,麻煩死了,向下看??
例:
//監(jiān)聽某個對象的某個屬性,返回的是信號。
[RACObserve(_tryla, text) subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
//用于給某個對象的某個屬性綁定。
RAC(_tryla,text) = _textField.rac_textSignal;
RACObserve是RAC的一個宏,需要傳入兩個參數(shù),要監(jiān)聽的對象和對象屬性,完成監(jiān)聽。
(6)rac_sequence.signal便利數(shù)組和字典
// 1.遍歷數(shù)組
NSArray *numbers = @[@1,@2,@3,@4];
[numbers.rac_sequence.signal subscribeNext:^(id x) {
NSLog(@"%@",x);
}];
// 2.遍歷字典,遍歷出來的鍵值對會包裝成RACTuple(元組對象)
NSDictionary *dict = @{@"name":@"xmg",@"age":@18};
[dict.rac_sequence.signal subscribeNext:^(RACTuple *x) {
// 解包元組,會把元組的值,按順序給參數(shù)里面的變量賦值
RACTupleUnpack(NSString *key,NSString *value) = x;
NSLog(@"%@ %@",key,value);
}];
就這些了,RAC功能強大無比,我了解的都只是一些皮毛而已??????