UISearchController

前言

  • 在 iOS 8.0 以上版本中, 我们可以使用 UISearchController 来非常方便地在 UITableView 中添加搜索框.
  • 而在之前版本中, 我们还是必须使用 UISearchDisplayController + UISearchBar 的组合方式.
  • 我们创建的 tableView 和搜索控制器创建的 tableView 都会走代理方法,需要在代理方法中判断响应代理方法的 tableView 是哪一个,
  • 如果响应代理方法的 tableView 不是我创建的,说明一定是搜索控制器创建的。
  • 在 iOS 8.0 以下版本中需使用 tableView == myTableView 判断,在 iOS 8.0 以上版本中需使用 mySearchController.active 判断。

1、搜索框的创建

  • 1.1 在 iOS 8.0 以下版本中

    • 1.1.1 遵守协议 UISearchDisplayDelegate

    • 1.1.2 搜索结果数组初始化

      // 声明搜索结果存放数组
      @property(nonatomic, retain)NSMutableArray *mySearchResultArray;
      
      // 初始化搜索结果存放数组
      mySearchResultArray = [[NSMutableArray alloc] init];
      
    • 1.1.3 searchDisplayController 初始化

      // 声明搜索控制器,自带一个表格视图,用来展示搜索结果,必须设置为全局变量
      @property(nonatomic, retain)UISearchDisplayController *mySearchDisplayController;
      
      // 实例化搜索条
      UISearchBar *searchBar = [[UISearchBar alloc] initWithFrame:CGRectMake(0, 0, self.view.frame.size.width, 44)];
      
      // 实例化搜索控制器对象
      mySearchDisplayController = [[UISearchDisplayController alloc] initWithSearchBar:searchBar contentsController:self];    
      // 设置搜索控制器的代理
      mySearchDisplayController.delegate = self;
      
      // 为搜索控制器自带 tableView 指定代理
      mySearchDisplayController.searchResultsDelegate = self;
      mySearchDisplayController.searchResultsDataSource = self;
      
      // 将搜索条设置为 tableView 的表头
      myTableView.tableHeaderView = searchBar;
      
    • 1.1.4 UISearchDisplayDelegate 协议方法

      // 更新搜索结果
      /*
      只要搜索框的文字发生了改变,这个方法就会触发。searchString 为搜索框内输入的内容。
      */
      - (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString {
      
      	// 清空上一次搜索的内容
      	[mySearchResultArray removeAllObjects];
      
      	// 将搜索的结果存放到数组中
      	for (NSArray *subArray in myDataArray) {
      		for (NSString *str in subArray) {
      			NSRange range = [str rangeOfString:searchString];
      			if (range.length) {
      				[mySearchResultArray addObject:str];
      			}
      		}
      	}
      	return YES;
      }
      
    • 1.1.5 UITableView 协议方法

    // 设置分段头标题
    - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section {
    
    	if (tableView == myTableView) {
    		return [NSString stringWithFormat:@"%c", (char)('A' + section)];
    	}
    	return @"搜索结果";
    }
    
    // 设置分段数
    - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
    
    	if (tableView == myTableView) {
    		return myDataArray.count;
    	}
    	return 1;
    }
    
    // 设置行数
    - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
    
    	if (tableView == myTableView) {
    		return [[myDataArray objectAtIndex:section] count];
    	}
    	return mySearchResultArray.count;
    }
    
    // 设置每段显示的内容
    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    
    	UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"testIdentifier"];
    
    	if (!cell) {
    		cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"testIdentifier"];
    	}
    
    	if (tableView == myTableView) {
    		cell.textLabel.text = [[myDataArray objectAtIndex:indexPath.section] objectAtIndex:indexPath.row];
    	}
    	else {
    		cell.textLabel.text = [mySearchResultArray objectAtIndex:indexPath.row];
    	}
    
    	return cell;
    }
    
  • 1.2 在 iOS 8.0 及以上版本中

    • 1.2.1 遵守协议 UISearchResultsUpdating

    • 1.2.2 搜索结果数组初始化

      // 声明搜索结果存放数组
      @property(nonatomic, retain)NSMutableArray *mySearchResultArray;
      
      // 初始化搜索结果存放数组
      mySearchResultArray = [[NSMutableArray alloc] init];
      
    • 1.2.3 searchController 初始化

      // 声明搜索控制器,自带一个表格视图控制器,用来展示搜索结果,必须设置为全局变量
      @property(nonatomic, retain)UISearchController *mySearchController;
      
      // 实例化搜索控制器
      mySearchController = [[UISearchController alloc] initWithSearchResultsController:nil];
      
      // 设置搜索代理
      mySearchController.searchResultsUpdater = self;
      
      // 设置搜索条大小
      [mySearchController.searchBar sizeToFit];
      
      // 设置搜索期间背景视图是否取消操作,default is YES
      mySearchController.dimsBackgroundDuringPresentation = NO;
      
      // 设置搜索期间是否隐藏导航条,default is YES
      mySearchController.hidesNavigationBarDuringPresentation = NO;
      
      // 将 searchBar 添加到表格的开头
      myTableView.tableHeaderView = mySearchController.searchBar;
      
    • 1.2.4 UISearchResultsUpdating 协议方法

      // 更新搜索结果
      /*
      只要搜索框的文字发生了改变,这个方法就会触发。searchController.searchBar.text 为搜索框内输入的内容
      */
      - (void)updateSearchResultsForSearchController:(UISearchController *)searchController {
      
      // 清除上一次的搜索结果
      [mySearchResultArray removeAllObjects];
      
      // 将搜索的结果存放到数组中
      for (NSArray *subArray in myDataArray) {
      	for (NSString *str in subArray) {
      
      			NSRange range = [str rangeOfString:searchController.searchBar.text];
      
      			if (range.length) {
      				[mySearchResultArray addObject:str];
      			}
      		}
      	}
      
      	// 重新加载表格视图,不加载的话将不会显示搜索结果
      	[myTableView reloadData];
      }
      
    • 1.2.5 UITableView 协议方法

    // 设置分段头标题
    - (NSString *)tableView:(UITableView *)tableView titleForHeaderInSection:(NSInteger)section {
    
    	if (mySearchController.active) {
    
    		return @"搜索结果";
    	}
    	return [NSString stringWithFormat:@"%c", (char)('A' + section)];
    }
    
    // 设置分段数
    - (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView {
    
    	if (mySearchController.active) {
    
    		return 1;
    	}
    	return myDataArray.count;
    }
    
    // 设置行数
    - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
    
    	if (mySearchController.active) {
    
    		return mySearchResultArray.count;
    	}
    	return [[myDataArray objectAtIndex:section] count];
    }
    
    // 设置每段显示的内容
    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {
    
    	UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:@"testIdentifier"];
    
    	if (!cell) {
    		cell = [[UITableViewCell alloc] initWithStyle:UITableViewCellStyleDefault reuseIdentifier:@"testIdentifier"];
    	}
    
    	if (mySearchController.active) {
    		cell.textLabel.text = [mySearchResultArray objectAtIndex:indexPath.row];
    	}
    	else {
    		cell.textLabel.text = [[myDataArray objectAtIndex:indexPath.section] objectAtIndex:indexPath.row];
    	}
    
    	return cell;
    }
    
posted @ 2018-11-12 23:00  CH520  阅读(156)  评论(0编辑  收藏  举报