iOS搜索页面-简单的字段(包含中英文)搜索与种类筛选

上周写了一个搜索界面,实现了搜索和简单筛选的小功能,在这里做一下记录与分享。

Github:看这里

iOS搜索控件有UISearchBar和UISearchController,有时也需要我们自定义一个搜索视图进行搜索功能的实现,但是对于一般的情况而言,我们通过KVC基本都能满足UI和产品方面的需求。在这里我用searchBar实现了一个简单的搜索筛选功能。

实现思路:

1、将请求到的数据存储在数据源数组中

2、动态控制搜索参数进行搜索

3、根据搜索条件,将符合条件的数据存储到搜索结果数组中

4、刷新视图

具体实现:

@interface XSSearchViewController (){

UISearchBar *_searchBar;//搜索栏

UITableView *_tableView;//主视图

UIView *_popView;//筛选视图

UIButton *_lastBtn;//筛选按钮暂存

}

@property (nonatomic, copy) NSString *queryText;//搜索字段

@property (nonatomic, assign) NSInteger type;//筛选类型

@property (nonatomic, strong) NSMutableArray *dataArray;//源数据

@property (nonatomic, strong) NSMutableArray *resultArray;//搜索数据

@end

/** 定义的数据筛选类型 */

typedef NS_ENUM(NSInteger,DateType) {

DateTypeAll,            //所有数据

DateTypePositive,      //正面

DateTypeVillain        //反面

};

实例化搜索控件:

_searchBar = [[UISearchBar alloc]initWithFrame:CGRectMake(0, 64, KScreenWidth, 40)];

_searchBar.placeholder = @"试试搜索人物信息";

_searchBar.delegate = self;

_searchBar.barTintColor = [UIColor whiteColor];//设置渲染颜色

_searchBar.backgroundImage = [UIImage new];//设置空背景图片

[self.view addSubview:_searchBar];

注:为了满足界面显示效果,有时需要将搜索栏边框进行隐藏,这里通过设置backgroundImage属性为[UIImage new]实现。

构建数据:

- (void)loadData{

NSArray *texts = @[@"李达康",@"侯亮平",@"陆亦可",@"沙瑞金",@"易学习",@"祁同伟",@"赵瑞龙",@"丁义珍",@"刘新建"];

NSArray *types = @[@"1",@"1",@"1",@"1",@"1",@"2",@"2",@"2",@"2"];

for (int i = 0; i < texts.count; i++) {

InfoModel *model = [[InfoModel alloc]init];

model.infoText = texts[i];

model.infoType = [types[i] integerValue];

[self.dataArray addObject:model];

}

_resultArray = [[NSMutableArray alloc]initWithArray:_dataArray];

[_tableView reloadData];

}

注:将_resultArray初始值赋为全部数据,在进行搜索操作时再根据搜索条件动态改变_resultArray的值,进行搜索结果的呈现。

根据搜索条件检索出数据:

- (void)searchInfo{

/**

这里我做了简单的本地检索,通过截取字符串进行简单比较。

但是在数据较多的情况下,一般我们通过获取searchBar上的文字,向后台发送搜索字段,接收后台返回的数据再进行数据的呈现。

*/

/** 搜索字段为空时,显示所有数据*/

if (_queryText.length == 0) {

for (InfoModel *model in self.dataArray) {

if (model.infoType == _type || _type == 0) {

[_resultArray addObject:model];

}

}

[_tableView reloadData];

_popView.hidden = YES;

return;

}

/** 搜索条件不为空时,遍历数据进行筛选*/

/**搜索字段为拼音时对数据进行遍历:

1、数据内容为中文-——》将中文字符串进行转换,然后与搜索字段进行比较

2、数据内容为拼音--》直接对字符串进行比较

注:拼音字符应不区分大小写

*/

if (_queryText.length > 0 && ![ChineseInclude isIncludeChineseInString:_queryText]) {

for (InfoModel *model in _dataArray) {

if ([ChineseInclude isIncludeChineseInString:model.infoText]) {

NSString *tempStr = [PinYinForObjc chineseConvertToPinYin:model.infoText];

NSRange range = [tempStr rangeOfString:_queryText options:NSCaseInsensitiveSearch];

if (range.length > 0) {

[_resultArray addObject:model];

}

}else{

NSRange range = [model.infoText rangeOfString:_queryText options:NSCaseInsensitiveSearch];

if (range.length > 0) {

[_resultArray addObject:model];

}

}

}

}else{/** 搜索字段为汉字时直接进行字符串比较*/

for (InfoModel *model in self.dataArray) {

NSRange range = [model.infoText rangeOfString:_queryText options:NSCaseInsensitiveSearch];

if (range.length > 0 && (model.infoType == _type || _type == DateTypeAll)) {

[_resultArray addObject:model];

}

}

}

[_tableView reloadData];

_popView.hidden = YES;

/** 无数据时添加提示*/

if (_resultArray.count == 0) {

[MyControl showWithFram:_tableView.frame propmt:@"暂无搜索结果" onView:self.view];

[self.view bringSubviewToFront:_popView];

}else{

[MyControl dismissFromView:self.view];

}

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容