专栏首页iOS开发笔记iOS开发-搜索栏UISearchBar和UISearchController

iOS开发-搜索栏UISearchBar和UISearchController

最近项目中用到了搜索栏,所以在网上搜了一些相关的资料学习了一下,现在记录一下,iOS中的搜索栏实现起来相对简单一点,网上也有很多参考资料,不过靠谱的不是很多,很多都是iOS 8.0之前的实现,iOS 8.0上的实现貌似很少看到,看了一些其他人的代码,使用了一下UISearchController感觉还是非常不错的。好了不多说了 ,来点干货吧。

1

UISearchBar和UIDisplayController实现搜索

是网上最常见的也算是最简单的,也有使用Searh Bar Search Display Controller的控件的,本文就简单的使用Search Bar和UITableView实现搜索Demo的,最上面的就是搜索栏,之前的就是TableView:

为了实现搜索需要声明委托 UISearchBarDelegate , UISearchDisplayDelegate,其中搜索主要使用的就是UISearchDisplayDelegate,具体代码实现过程:

声明字段:

@property (strong,nonatomic) NSMutableArray *dataList;

@property (strong,nonatomic) NSMutableArray *searchList;

初始化数据:

self.dataList=[NSMutableArray arrayWithCapacity:100];    for (NSInteger i=0; i<100; i++) {
 [self.dataList addObject:[NSString stringWithFormat:@"%ld-FlyElephant",(long)i]];
   }

设置区域:

//设置区域-(NSInteger)numberOfSectionsInTableView:(UITableView *)tableView{     return 1;}

设置区域的行数(重点),这个就是使用委托之后需要需要判断是一下是否是需要使用Search之后的视图:

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

同样的返回单元格也有两种情况,一种是初始化数据,一种是过滤之后的数据视图:

-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{  static NSString *flag=@"cellFlag";  UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:flag];  if (cell==nil) {    cell=[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:flag];  }  if (tableView==self.searchDisplayController.searchResultsTableView) {   [cell.textLabel setText:self.searchList[indexPath.row]];  }  else{    [cell.textLabel setText:self.dataList[indexPath.row]];  }  return cell;}

UISearchBarDelegate中德 开始和结束的事件:

- (BOOL)searchBarShouldBeginEditing:(UISearchBar *)searchBar{  NSLog(@"搜索Begin");  return YES; } - (BOOL)searchBarShouldEndEditing:(UISearchBar *)searchBar{  NSLog(@"搜索End"}- (BOOL)searchBarShouldEndEditing:(UISearchBar *)searchBar{  NSLog(@"搜索End");  return YES;}

搜索时过滤数据:

- (BOOL)searchDisplayController:(UISearchDisplayController *)controller shouldReloadTableForSearchString:(NSString *)searchString{  // 谓词的包含语法,之前文章介绍过http://www.cnblogs.com/xiaofeixiang/  NSPredicate *preicate = [NSPredicate predicateWithFormat:@"SELF CONTAINS[c] %@", searchString];  if (self.searchList!= nil) {    [self.searchList removeAllObjects];  } //过滤数据  self.searchList= [NSMutableArray arrayWithArray:[_dataList filteredArrayUsingPredicate:preicate]];  //刷新表格  return YES;}

最终效果如下:

2

UISearchController实现搜索

UISeachBar通过UISearchDisplayDelegate实现上面的效果是没有问题的,网上也有很多类似的实现效果,不过是警告的,信息如下: 'searchDisplayController' is deprecated: first deprecated in iOS 8.0,这么明显一个警告总不能视而不见吧 ,也就是说 iOS 8.0 不推荐 UISearchDisplayController, 也就是不推荐使用 UISearchDisplayDelegate ,但是可以通过 UISearchController 实现 UISearchResultsUpdating 这个委托实现上面的效果;

视图中中需要声明UISearchResultsUpdating:

@interface ViewController : UITableViewController<UITableViewDelegate,UITableViewDataSource,UISearchBarDelegate,UISearchResultsUpdating>

@end

属性声明:

@property (nonatomic, strong) UISearchController *searchController;

需要自己初始化一下UISearchController:

_searchController = [[UISearchController alloc] initWithSearchResultsController:nil];

_searchController.searchResultsUpdater = self;

_searchController.dimsBackgroundDuringPresentation = NO;

_searchController.hidesNavigationBarDuringPresentation = NO;

_searchController.searchBar.frame = CGRectMake(self.searchController.searchBar.frame.origin.x, self.searchController.searchBar.frame.origin.y, self.searchController.searchBar.frame.size.width, 44.0);

self.tableView.tableHeaderView = self.searchController.searchBar;

之前是通过判断搜索时候的TableView,不过现在直接使用self.searchController.active进行判断即可,也就是UISearchController的active属性:

//设置区域的行数-(NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{      if (self.searchController.active) {        return [self.searchList count];      }else{        return [self.dataList count];     }}//返回单元格内容-(UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{  static NSString *flag=@"cellFlag";  UITableViewCell *cell=[tableView dequeueReusableCellWithIdentifier:flag];  if (cell==nil) {    cell=[[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:flag];  }  if (self.searchController.active) {    [cell.textLabel setText:self.searchList[indexPath.row]]; }  else{    [cell.textLabel setText:self.dataList[indexPath.row]];  }  return cell;}

具体调用的时候使用的方法也发生了改变,这个时候使用updateSearchResultsForSearchController进行结果过滤:

-(void)updateSearchResultsForSearchController:(UISearchController *)searchController {  NSString *searchString = [self.searchController.searchBar text];  NSPredicate *preicate = [NSPredicate predicateWithFormat:@"SELF CONTAINS[c] %@", searchString];  if (self.searchList!= nil) {   [self.searchList removeAllObjects];  }  //过滤数据  self.searchList= [NSMutableArray arrayWithArray:[_dataList filteredArrayUsingPredicate:preicate]];  //刷新表格  [self.tableView reloadData];}

效果演示如上所示。

本文分享自微信公众号 - iOS开发笔记(roclel),作者:不羁的风

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2016-01-20

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • cordova插件-File Transfer

    添加插件 $ cordova plugin addcordova-plugin-file-transfer ? 图 15如上则插入成功 插件的使用 Meth...

    roc
  • iOS开发之-调用系统打电话功能

    调用系统打电话功能有点简单,不需要遵守协议和代理什么的,直接在执行打电话的方法里写上几句代码就可以了

    roc
  • iOS开发之-调用系统打电话功能

    调用系统打电话功能有点简单,不需要遵守协议和代理什么的,直接在执行打电话的方法里写上几句代码就可以了

    roc
  • supervisor源码解析

    上篇文章介绍了supervisor的使用, 今天介绍一下supervisor的源码。 supervisor是python写的。如果你不懂python,我也介绍一...

    若与
  • MJRefresh 源码阅读

    用户2215591
  • python实现坦克大战

    砸漏
  • 剑指offer【30~39】

    除了存储数据的栈 stack,再定义一个最小栈 minstack。minstack 的长度和 stack 保持同步,只不过其是一个递减栈。如 stack = [...

    echobingo
  • Python3使用requests模块显

    请求关键参数:stream=True。默认情况下,当你进行网络请求后,响应体会立即被下载。你可以通过 stream 参数覆盖这个行为,推迟下载响应体直到访问 R...

    py3study
  • 阅读器多种翻页的设计与实现

    UIKit提供UIPageViewController可以很方便实现平移的页面切换效果,使用流程: 1、创建UIPageViewController;

    落影
  • PaddleX助力无人驾驶:基于YOLOv3的车辆检测和车道线分割实战

    无人驾驶汽车利用传感器技术、信号处理技术、通讯技术和计算机技术等,通过集成视觉、激光雷达、超声传感器、微波雷达、GPS、里程计、磁罗盘等多种车载传感器来辨识汽车...

    用户1386409

扫码关注云+社区

领取腾讯云代金券