OGeek|极客世界-中国程序员成长平台

标题: ios - 用于删除孤立对象的 RestKit NSFetchRequest block [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-13 05:59
标题: ios - 用于删除孤立对象的 RestKit NSFetchRequest block

我在我的 .com 域上托管了一个 Rest api,它在收到这样的 www.mydomain.com/api/lists 请求时将返回如下所示的 json 格式数据

[
    {"list_id":"1","listName":"List Name 1"},
    {"list_id":"2","listName":"List Name 2"},
    {"list_id":"5","listName":"List Name 3"},
    {"list_id":"7","listName":"List Name 4"},
    {"list_id":"8","listName":"List Name 5"},
    {"list_id":"11","listName":"List Name 6"},
    {"list_id":"12","listName":"List Name 7"}
]

现在我在我的 RKObjectManger 中添加一个 NSFetchRequest block 以使用此代码检查孤立对象

[objectManager addFetchRequestBlock:^NSFetchRequest *(NSURL *URL) {
        RKPathMatcher *pathMatcher = [RKPathMatcher pathMatcherWithPattern"/api/lists"];

        NSDictionary *argsDict = nil;
        BOOL match = [pathMatcher matchesPath:[URL relativePath] tokenizeQueryStrings:NO     parsedArguments:&argsDict];
        NSString *listID;
        if (match)
        {
            listID = [argsDict objectForKey"list_id"];
            NSLog(@"The listID is %@",listID);
            NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
            NSEntityDescription *entity = [NSEntityDescription entityForName"List"
                                                      inManagedObjectContext:managedObjectStore.persistentStoreManagedObjectContext];
            [fetchRequest setEntity:entity];
            fetchRequest.predicate = [NSPredicate predicateWithFormat"listID = %@", @([listID integerValue])]; 
            return fetchRequest;
        }

        return nil;
    }];

但我的 listID = [argsDict objectForKey"list_id"]; 返回 nil,尽管从 web 返回的 json 中包含“list_id”。请指导我这里出了什么问题。



Best Answer-推荐答案


你不能这样做:

listID = [argsDict objectForKey"list_id"];
NSLog(@"The listID is %@",listID);

因为路径模式 /api/lists 中没有 list_id 参数。因此,如果缺少此数据,您的谓词将始终检查错误的 listID

但是,你不需要这些。假设请求从服务器返回所有对象——你应该使用 fetch block 的唯一时间——那么你不需要谓词。只需为实体创建一个获取请求并返回它而不使用任何谓词。

关于ios - 用于删除孤立对象的 RestKit NSFetchRequest block ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21232402/






欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://sqlite.in/) Powered by Discuz! X3.4