网上好多方法都是在UISearchDisplayDelegate的方法中添加修改子视图的代码,如下所示:
还是放到一样的代理方法中。经测试无问题。目前对于dispatch之类的东东还不是很熟悉,大概意思能看出来是推迟了方法的执行,保证执行的时候这个UILabel已经被添加到父视图上。(真的能万无一失的确保吗?)
- (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString
{
[self filterContentForSearchText:searchString];
if ([filteredListPinYin count] == 0) {
UITableView *tableView1 = self.searchDisplayController.searchResultsTableView;
for( UIView *subview in tableView1.subviews ) {
if( [subview class] == [UILabel class] ) {
UILabel *lbl = (UILabel*)subview; // sv changed to subview.
lbl.text = @”没有结果”;
}
}
}
// Return YES to cause the search result table view to be reloaded.
return YES;
}
经过自己实际使用,发现一个问题,在第一次没有搜索到数据的情况下,上面代码中并没有执行if判断,也就是说没有符合条件的子视图,所以显示出来还是no results,而当第二次搜索可以正常显示『没有结果』。因此我猜想,在第一次要展示的时候,这个要展示no result的UILabel视图还没有添加到父视图上,是之后才创建的。之后又去网上搜索了一下找到如下解决办法:
dispatch_time_t popTime = dispatch_time(DISPATCH_TIME_NOW, 0.001);
dispatch_after(popTime, dispatch_get_main_queue(), ^(void){
for (UIView* v in self.searchDisplayController.searchResultsTableView.subviews) {
if ([v isKindOfClass: [UILabel class]])
{
UILabel *lbl = (UILabel *)v;
[lbl setText:@"无结果"];
break;
}
}
});
还是放到一样的代理方法中。经测试无问题。目前对于dispatch之类的东东还不是很熟悉,大概意思能看出来是推迟了方法的执行,保证执行的时候这个UILabel已经被添加到父视图上。(真的能万无一失的确保吗?)