ReactiveCocoa链接网络操作失败

时间:2015-04-22 10:39:48

标签: objective-c parse-platform reactive-cocoa

我尝试使用ReactiveCocoa进行网络操作链接,但是我失败了。我无法弄清楚我的代码有什么问题。

- (RACSignal *)pg_findObjectsInBackground {
    return [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {

        [self findObjectsInBackgroundWithBlock:^(NSArray *objects, NSError *error) {
            if (error) {
                [subscriber sendError:error];
                return;
            }
            [subscriber sendNext:objects];
            [subscriber sendCompleted];
        }];

        return [RACDisposable disposableWithBlock:^{
            [self cancel];
        }];
    }];
}

- (RACSignal *)pg_countObjectsInBackground {
    return [RACSignal createSignal:^RACDisposable *(id<RACSubscriber> subscriber) {

        [self countObjectsInBackgroundWithBlock:^(int number, NSError *error) {
            if (error) {
                [subscriber sendError:error];
                return;
            }
            [subscriber sendNext:@(number)];
            [subscriber sendCompleted];
        }];

        return [RACDisposable disposableWithBlock:^{
            [self cancel];
        }];
    }];
}
    __block NSError *_error;
    @weakify(self)
    [[[self.query pg_countObjectsInBackground]flattenMap:^RACStream *(NSNumber *count) {
        @strongify(self)
        self.totalCount = [count integerValue];
        // Second, fetch experiences
        self.query.limit = self.pageSize;
        self.query.skip = self.pageSize * self.currentPage;
        return [self.query pg_findObjectsInBackground];
    }]subscribeNext:^(NSArray *experiences) {
        @strongify(self)
        [self.experiences removeAllObjects];
        [self.experiences addObjectsFromArray:experiences];
    } error:^(NSError *error) {
        _error = error;
    } completed:^{
        @strongify(self)
        if (finishBlock) {
            finishBlock(self, _error);
        }
    }];

第一个请求成功了。但是一旦我返回[self.query pg_findObjectsInBackground],它就会直接转到disposableWithBlock

1 个答案:

答案 0 :(得分:0)

因为您对count和find对象操作使用相同的PFQuery对象,所以当您从flattenMap方法返回时,查询将被取消。 flattenMap订阅新信号(这是相同的信号),我认为这会导致一次性发射。一个简单的解决方案是构造一个新的PFQuery并将其返回flattenMap块。

我认为你正在使用Parse,如果你是,你应该标记它。