Objective c 在编辑模式下将UISearchBar与UITableView一起使用时,搜索结果不在编辑模式下

Objective c 在编辑模式下将UISearchBar与UITableView一起使用时,搜索结果不在编辑模式下,objective-c,ios,xcode,uitableview,uisearchbar,Objective C,Ios,Xcode,Uitableview,Uisearchbar,我有一个表视图控制器,它实现了UISearchBarDelegate和UISearchDisplayDelegate。我有一个按钮来切换我的表视图的编辑视图。当处于编辑模式时,用户可以选择许多行并复制、删除它们,等等。如果我尝试在搜索栏中输入一些内容,而表视图处于编辑模式,则会触发shouldReloadTableForSearchString方法,然后我使用更新的谓词从核心数据中重新获取数据,并从函数返回YES,指示应重新加载表视图。显示过滤后的结果时,它们不处于编辑模式,即使在cellFor

我有一个表视图控制器,它实现了UISearchBarDelegate和UISearchDisplayDelegate。我有一个按钮来切换我的表视图的编辑视图。当处于编辑模式时,用户可以选择许多行并复制、删除它们,等等。如果我尝试在搜索栏中输入一些内容,而表视图处于编辑模式,则会触发shouldReloadTableForSearchString方法,然后我使用更新的谓词从核心数据中重新获取数据,并从函数返回YES,指示应重新加载表视图。显示过滤后的结果时,它们不处于编辑模式,即使在cellForRowAtIndexPath中,我可以看到tableView IsEdit是YES。我看不到多重选择的圆圈。在选择几个项目之前,我需要能够让用户过滤他们的列表,以便显著限制结果

为什么结果不以编辑模式显示

编辑模式,不使用搜索栏:

在编辑模式下搜索会生成不在编辑模式下且未设置样式的结果:

提前感谢,, 亚历克斯

以下是shouldReloadTableForSearchString方法:

    - (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString {
NSPredicate *predicate = nil;
if ([searchString length])
{
    NSArray* filteredTags = nil;
    if ([searchString length] < 3)
    {
        // Check for tags starting with 1 or 2 characters.
        filteredTags = [[tagResultsController fetchedObjects] filteredArrayUsingPredicate:[NSPredicate predicateWithBlock:^BOOL(TagEntity* te, NSDictionary *bindings)
        {
            if ([[[te.name lowercaseString] substringToIndex:[searchString length]] isEqualToString:[searchString lowercaseString]])
                return YES;

            return NO;
        }]];

    }
    else
    {
        // Check for tags with 3 or more consecutive characters anywhere in name
        filteredTags = [[tagResultsController fetchedObjects] filteredArrayUsingPredicate:[NSPredicate predicateWithBlock:^BOOL(TagEntity* te, NSDictionary *bindings)
        {
           if ([[te.name lowercaseString] rangeOfString:[searchString lowercaseString]].location != NSNotFound)
               return YES;

           return NO;
        }]];
    }

    //  OR ANY(self.tags) in %@
    predicate = [NSPredicate predicateWithFormat:
        @"ANY(self.songlists) in %@ AND (name contains[cd] %@ OR artist_name contains[cd] %@ OR number = %@ OR ANY(tag_entities) in %@)",
        currentSonglist.songs, searchString, searchString, searchString,filteredTags];

    [self.fetchedResultsController.fetchRequest setPredicate:predicate];

    NSError *error = nil;
    if (![[self fetchedResultsController] performFetch:&error]) {
        NSLog(@"Unresolved error %@, %@", error, [error userInfo]);
        abort();
    }
    // Return YES to cause the search result table view to be reloaded.

}

return YES;
}

我使用分段控件内的按钮来打开/关闭编辑:

    - (IBAction)segmentChanged:(id)sender{
UISegmentedControl* sg = (UISegmentedControl*)sender;
if (sg.selectedSegmentIndex == 0)
{
    // Edit
    if (![self.tableView isEditing])
    {
        [self.tableView setEditing:YES animated:YES];
        [self.navigationController setToolbarHidden:NO animated:YES];
    }
    else
    {
        [self.tableView setEditing:NO animated:YES];
        [self.navigationController setToolbarHidden:YES animated:YES];
        selectedIndexes = nil;
    }
    [self.tableView reloadData];
}
else
{
    // Sort
    if (pickerShown)
        [self sendPickerDownAnimated:YES];
    else
        [self bringPickerUpAnimated:YES];
}

}

问题在于UISearchDisplayController自动为您做了很多事情。它创建自己的表视图以显示搜索结果,并管理该表视图。您可以将自己设置为该表视图的数据源和委托,默认情况下,这是自动完成的,但它不是您的表视图,您无法控制它。如果您想让更多的人来指定这是什么表视图,则需要设置搜索显示控制器的
searchResultsTableView
;或者,您也可以在运行过程中获得对它的引用(例如,通过UISearchDisplayController自己的委托方法)。但即使如此,您也不会成为管理结果表视图的UITableViewController;这完全是UISearchDisplayController内部的。如果您不喜欢这样,一个简单的解决方案是:不要使用UISearchDisplayController-考虑另一个界面。

如matt所说,而在搜索模式下,UISearchDisplayController有自己的UITableView,因此,在编辑模式下,要在UITableView中保留相同的设计,需要将在self.tableView中设置的相同设计参数传递给UITableView

-(void)searchDisplayController:(UISearchDisplayController *)controller didLoadSearchResultsTableView:(UITableView *)tableView
{
    tableView.backgroundColor = self.tableView.backgroundColor;
    tableView.separatorColor = [UIColor redColor];
    tableView.separatorInset = UIEdgeInsetsMake(0, 0, 0, 0);
}

UISearchDisplayController为显示搜索结果而创建的表视图是另一个表视图。事实上,你没有得到的样式是非常明显的;听起来好像你不是在和你认为在和你说话的表视图说话。如果您展示一些代码,可能会有所帮助,因为没有人能猜到您是如何做到这一点的。。。您可能会更乐于创建自己的界面,而不使用UISearchDisplayController…谢谢。我包括了一些代码。我确信正在使用我的表视图,因为当我从搜索结果中单击该行时,didSelectRowAtIndexPath将正常启动。在那一点上,我的编辑仍然是肯定的。你能分享你使表格可编辑和不可编辑的代码吗?是的。我把它加在了最后。它几乎只是:[self.tableView setEditing:YES动画:YES];是的,但我刚才说UISearchDisplayController为您创建的表视图是一个不同的表视图。设置有关
self.tableView
的内容不会对其产生任何影响。这就是我的全部观点
didSelectRow
是一个委托方法,因此这与此无关。我没有说你不是这个表视图的代表;你是,自动地。我说这是一个不同的表视图,您可能需要意识到这一事实的含义。您知道有任何示例代码/项目在搜索结果中实现了多项选择吗?
    - (IBAction)segmentChanged:(id)sender{
UISegmentedControl* sg = (UISegmentedControl*)sender;
if (sg.selectedSegmentIndex == 0)
{
    // Edit
    if (![self.tableView isEditing])
    {
        [self.tableView setEditing:YES animated:YES];
        [self.navigationController setToolbarHidden:NO animated:YES];
    }
    else
    {
        [self.tableView setEditing:NO animated:YES];
        [self.navigationController setToolbarHidden:YES animated:YES];
        selectedIndexes = nil;
    }
    [self.tableView reloadData];
}
else
{
    // Sort
    if (pickerShown)
        [self sendPickerDownAnimated:YES];
    else
        [self bringPickerUpAnimated:YES];
}
-(void)searchDisplayController:(UISearchDisplayController *)controller didLoadSearchResultsTableView:(UITableView *)tableView
{
    tableView.backgroundColor = self.tableView.backgroundColor;
    tableView.separatorColor = [UIColor redColor];
    tableView.separatorInset = UIEdgeInsetsMake(0, 0, 0, 0);
}