ReactiveCocoa<二>

建议参考:
http://benbeng.leanote.com/post/ReactiveCocoaTutorial-part1 这事一篇写的非常不错的关于rac编程的博客

理解

Signal在管道中传输,Subscriber是接通并延长管道的一节管子,延长到你要接水(使用Signal)的地方。要有Subscriber的时候Signal才能通过这个点,到达你要使用的地方。

使用

新建一个工程,最好还是使用CocoaPods吧,那样会节省你很多的时间。

接下来就开始上代码了。
在StoryBoard中

在VC中配置

[[self.firText rac_textSignal] subscribeNext:^(id x) {
        NSLog(@"第一个textFiled的值%@",x);
    }];
    [[self.secText rac_textSignal] subscribeNext:^(id x) {
        NSLog(@"第二个textFiled的值%@",x);
    }];

把上面的代码加入到ViewDidLoad中,然后模拟器运行,就可以看到log打印出来textfiled中实时变化的值。查看rac_testSignal这个方法;

ReactiveCocoa框架中有对UI界面做好的扩展, rac_textSignal是对TextFiled的扩展,description中写的很清楚,返回一个Signal。可以理解为rac_textSignal是对textFiled创建一个实时的管道,返回一个Signal。在需要使用的地方就要对这个管道进行扩展。接下来就用这个思想进行响应式编程。

吃到肚子里

为了深入的理解,写几句废代码
在viewController中写两个私有方法

//自己创建一条管道
- (RACSignal *)rac_firTextFilterSingal{
    return [self.firText rac_textSignal];
}

- (RACSignal *)rac_secTextFilterSingal{
    return [self.secText rac_textSignal];
}

再在viewDidLoad中

[[self rac_firTextFilterSingal] subscribeNext:^(id x) {
        NSLog(@"第一个textFiled的值%@",x);

    }];

    [[self rac_secTextFilterSingal] subscribeNext:^(id x) {
        NSLog(@"第二个textFiled的值%@",x);
    }];

跟上面是一样的效果
本人感觉有点废,但是为了更深的理解,就从这里开始。
Signal是很灵活的,它可以被修改(map),过滤(filter),叠加(combine),串联(chain),这有助于应对更加复杂的情况,这里就不再多叙了,大家自己研究研究。

项目中使用

CocoaPod中已经引入了
AFNetworking-RACExtensions
如果你项目正规一点,那么你会写一个网络请求的单例类,

@interface MyNetWorkManager : NSObject
{
    AFHTTPRequestOperationManager *_httpClient;
}
+ (MyNetWorkManager *)defaultInstance;
- (RACSignal *)rac_getAdvertimages; - (RACSignal *)rac_getDropDownImages; - (RACSignal *)rac_getAllImage; @end
@implementation MyNetWorkManager
static MyNetWorkManager *defaultInscance;
+ (MyNetWorkManager *)defaultInstance{
    //static MyNetWorkManager *defaultInscance;
    @synchronized (self){
        if (defaultInscance == nil) {
            defaultInscance = [[MyNetWorkManager alloc] init];
        }
    }
    return defaultInscance;
}
- (MyNetWorkManager *) init{
    self = [super init];
    if (self) {
        // Nsstring *baseUrl = [Nsstring stringWithFormat:@""];
        _httpClient = [[AFHTTPRequestOperationManager alloc] initWithBaseURL:[NSURL URLWithString:@"http://lanou.mylanou.com:80/rest/api/"]];
        _httpClient.requestSerializer = [AFJSONRequestSerializer serializer];
        _httpClient.responseSerializer = [AFJSONResponseSerializer serializer];
    }
    return self;
}

- (RACSignal *)rac_getAdvertimages{
    return [[_httpClient rac_POST:@"app/image/advert/get" parameters:nil] map:^id(id value) {
        NSDictionary *rootDic = value;
        return rootDic;
    }];
}
- (RACSignal *)rac_getDropDownImages{
    return [[_httpClient rac_POST:@"app/image/advert/drop-down/get" parameters:nil] map:^id(id value) {
        NSDictionary *rootdic = value;
        return rootdic;
    }];
}
- (RACSignal *)rac_getAllImage{
    return [[_httpClient rac_POST:@"/shopping/if-open" parameters:nil] map:^id(id value) {
        NSDictionary *rootdic = value;
        return rootdic;
    }];
}

在viewDidLoad中调用一下

[[[MyNetWorkManager defaultInstance]  rac_getAdvertimages] subscribeNext:^(id x) {
        NSLog(@"xxxxxxxxxxxxxxxxxx%@",x);
    }];

    [[[MyNetWorkManager defaultInstance] rac_getDropDownImages] subscribeNext:^(id x) {
        NSLog(@"yyyyyyyyyyyyyyyy\n%@",x);
    }];

    [[[MyNetWorkManager defaultInstance] rac_getAllImage] subscribeNext:^(id x) {
        NSLog(@"alllllllllllllllllll%@",x);
    }];

当然你也可以把url的参数和后面拼接的部分当成参数封装到外面。

相关文章

一、前言 在组件方面react和Vue一样的,核心思想玩的就是组件...
前言: 前段时间学习完react后,刚好就接到公司一个react项目...
前言: 最近收到组长通知我们项目组后面新开的项目准备统一技...
react 中的高阶组件主要是对于 hooks 之前的类组件来说的,如...
我们上一节了解了组件的更新机制,但是只是停留在表层上,例...
我们上一节了解了 react 的虚拟 dom 的格式,如何把虚拟 dom...