2014-12-03 110 views
0

我正在尝试创建一个搜索栏,它将用来自两个数据源(本地& API调用)的结果更新UITableView。我正在努力找出实现这一点的正确方法。filterContentForSearchText不在UITableView上显示数据

我有一个UITableView设置为顶部有搜索栏的用户列表。

enter image description here

当我有设置为与本地SEARCHTEXT过滤UITableCells代码它完美。

enter image description here

然而,从解析拉动数据,并试图加入,在细胞下方的本地搜索数据时没有出现。

enter image description here

的代码正确地更新self.searchText阵列但数据在的tableView从不显示。是什么赋予了?

- (void)filterContentForSearchText:(NSString*)searchText scope:(NSString*)scope 
{ 
    [self.searchResult removeAllObjects]; 
    NSPredicate *resultPredicate = [NSPredicate predicateWithFormat:@"name contains[c] %@", searchText]; 

    NSMutableArray *queryArray = [[NSMutableArray alloc] init]; 
    PFQuery *query = [PFUser query]; 
    [query whereKey:@"fullName" hasPrefix:@"Joe"]; 
    [query findObjectsInBackgroundWithBlock:^(NSArray *objects, NSError *error) { 
    if (!error) { 
     for (PFObject *pfObj in objects) 
     { 
      NSDictionary *person = [[NSDictionary alloc] 
            initWithObjects:@[pfObj[@"fullName"], pfObj.objectId] 
            forKeys:@[@"name", @"objectId"]]; 
      [queryArray addObject:person]; 
     } 

     self.searchResult = [NSMutableArray arrayWithArray: [self.contacts filteredArrayUsingPredicate:resultPredicate]]; 
     [self.searchResult addObjectsFromArray:queryArray]; 
    } else { 
     NSLog(@"%@", error); 
    } 
}];  
} 

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath 
{ 
    static NSString *CellIdentifier = @"Cell"; 

    UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier]; 

    if (cell == nil) 
    { 
     cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:CellIdentifier]; 
    } 

    if (tableView == self.searchDisplayController.searchResultsTableView) 
    { 
     cell.textLabel.text = [self.searchResult[indexPath.row] objectForKey:@"name"]; 
    } 
    else 
    { 
     cell.textLabel.text = [self.contacts[indexPath.row] objectForKey:@"name"]; 
    } 

    return cell; 
} 

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section 
{ 
    if (tableView == self.searchDisplayController.searchResultsTableView) 
    { 
     return [self.searchResult count]; 
    } 
    else 
    { 
     return [self.contacts count]; 
    } 
} 
+0

您是否实施了多少次浮动?在此处发布 – Pawan 2014-12-03 06:38:44

+0

在完成从分析中加载数据后,您需要重新加载tableView。确保你在主队列上执行此操作 – Paulw11 2014-12-03 06:43:45

+0

@pawan是的,我已经实现了numberOfRowsInSection。我已经相应地更新了我的帖子。 – 2014-12-03 17:15:20

回答

1

也许你从服务器获取数据,这样,当它调用方法

- (void)filterContentForSearchText:(NSString*)searchText scope:(NSString*)scope 

重新加载与当前阵列self.searchResult,它现在已经没有值的表。所以,我认为你应该重新加载搜索表中的数据是从是

if (!error) { 
     for (PFObject *pfObj in objects) 
     { 
      NSDictionary *person = [[NSDictionary alloc] 
            initWithObjects:@[pfObj[@"fullName"], pfObj.objectId] 
            forKeys:@[@"name", @"objectId"]]; 
      [queryArray addObject:person]; 
     } 

     self.searchResult = [NSMutableArray arrayWithArray: [self.contacts filteredArrayUsingPredicate:resultPredicate]]; 
     [self.searchResult addObjectsFromArray:queryArray]; 
[self.searchDisplayController.searchResultsTableView reloadData]; 
    } else { 
     NSLog(@"%@", error); 
    } 

而且据我来说,最好的办法是首先应该显示本地结果服务器检索之后 - 直到的休息联系人从Parse加载,也就是说。

- (void)filterContentForSearchText:(NSString*)searchText scope:(NSString*)scope 
{ 
    [self.searchResult removeAllObjects]; 
    NSPredicate *resultPredicate = [NSPredicate predicateWithFormat:@"name contains[c] %@", searchText]; 
    self.searchResult = [NSMutableArray arrayWithArray: [self.contacts filteredArrayUsingPredicate:resultPredicate]]; 

    NSMutableArray *queryArray = [[NSMutableArray alloc] init]; 
    PFQuery *query = [PFUser query]; 
    [query whereKey:@"fullName" hasPrefix:@"Joe"]; 
    [query findObjectsInBackgroundWithBlock:^(NSArray *objects, NSError *error) { 
    if (!error) { 
     for (PFObject *pfObj in objects) 
     { 
      NSDictionary *person = [[NSDictionary alloc] 
            initWithObjects:@[pfObj[@"fullName"], pfObj.objectId] 
            forKeys:@[@"name", @"objectId"]]; 
      [queryArray addObject:person]; 
     } 
     [self.searchResult addObjectsFromArray:queryArray]; 
     self.searchDisplayController.searchResultsTableView reloadData]; 
    } else { 
     NSLog(@"%@", error); 
    } 
}];  
} 
+0

它的工作原理!感谢您的帮助! – 2014-12-03 17:24:17