iOS - 模糊搜索 2

 789197E767510C4D8BA0FAD6F83686A9.png
789197E767510C4D8BA0FAD6F83686A9.png

 1C918AFB0DE8C3BD4B54DA3FA53F6AE7.png
1C918AFB0DE8C3BD4B54DA3FA53F6AE7.png

 23F88AF25F11F76455D5DD58E7BE184D.png
23F88AF25F11F76455D5DD58E7BE184D.png

前言:简单版可查看 模糊搜索 1 博客

一、申明相关属性和代理

    <UITableViewDelegate,UITableViewDataSource,UIGestureRecognizerDelegate,UISearchBarDelegate>

    /// tableView 搜索页
    @property (nonatomic , strong) UIView *tableBGView;
    @property (nonatomic , strong) UITableView *tableSearchView;
    
    //数据源
    @property (nonatomic , strong) NSMutableArray *dataList;
    @property (nonatomic , strong) NSMutableArray *searchList;
    @property (nonatomic , copy) NSString *inputString;

**
二、创建导航栏视图 ,MSUHomeNavView**

1.MSUHomeNavView.h 中的代码
    /// 返回按钮
    @property (nonatomic , strong) UIButton *backArrowBtn;
    /// 搜索框按钮
    @property (nonatomic , strong) UISearchBar *search;

2.MSUHomeNavView.m 中的代码

    - (instancetype)initWithFrame:(CGRect)frame showNavWithNumber:(NSInteger)number
    {
        if (self = [super initWithFrame:frame]) {
            switch (number) {
                  case 58:
            {
                /// 确认订单页面
                [self createbackNavViewWithTyper:number];
            }
                break;
                default:
                    break;
            }
        }
        return self;
    }

        - (void)createbackNavViewWithTyper:(NSInteger)typer{
            /// 取消按钮
            self.backArrowBtn = [UIButton buttonWithType:UIButtonTypeCustom];
            [self addSubview:_backArrowBtn];
            [_backArrowBtn setTitle:@"取消" forState:UIControlStateNormal];
            _backArrowBtn.titleLabel.font = [UIFont systemFontOfSize:14];
            [_backArrowBtn setTitleColor:HEXCOLOR(0xffffff) forState:UIControlStateNormal];
            [_backArrowBtn makeConstraints:^(MASConstraintMaker *make) {
                make.top.equalTo(self.top).offset(0);
                make.left.equalTo(self.left).offset(14);
                make.width.equalTo(30);
                make.height.equalTo(40);
            }];

            /// 搜索框
        //    self.search = [[UISearchBar alloc]initWithFrame:CGRectMake(40, 6, WIDTH-40-14, 28)];
        //    _search.placeholder =  @"搜索感兴趣的内容";
        //    _search.searchBarStyle = UISearchBarStyleMinimal;
        //    _search.backgroundImage = [self imageWithColor:WHITECOLOR size:_search.bounds.size];
        //    [self addSubview:_search];
            
            self.search = [[UISearchBar alloc]initWithFrame:CGRectMake(48, 3, WIDTH-40-14, 34)];
            _search.placeholder =  @"搜索您的小伙伴";
            _search.backgroundImage = [self imageWithColor:WHITECOLOR size:_search.bounds.size];
            _search.layer.borderColor = NavColor.CGColor;
            _search.layer.borderWidth = 2;
            _search.layer.cornerRadius = 7;
            _search.clipsToBounds = YES;
            [self addSubview:_search];
            
        }

三、控制器中代码

    - (void)viewDidLoad {
        [super viewDidLoad];
        // Do any additional setup after loading the view.
    
        self.nav = [[MSUHomeNavView alloc] initWithFrame:NavRect showNavWithNumber:numer];
        [self.view addSubview:_nav];
        _nav.search.delegate = self;
       
         [self createTableView];
    }

    /* 搜索列表视图 */
    - (void)createTableView{
        self.tableBGView = [[UIView alloc] initWithFrame:CGRectMake(0, 60, WIDTH, HEIGHT-60)];
        _tableBGView.backgroundColor = HEXCOLOR(0xf4f4f4);
        _tableBGView.hidden = YES;
        [self.view addSubview:_tableBGView];
        
        // 列表初始化
        self.tableSearchView = [[UITableView alloc] initWithFrame:CGRectMake(0, 10,WIDTH ,HEIGHT-60-10) style:UITableViewStylePlain];
        _tableSearchView.delegate = self;
        _tableSearchView.dataSource = self;
        _tableSearchView.separatorStyle = UITableViewCellSelectionStyleNone;
        //    _tableView.bounces = NO;
        _tableSearchView.showsVerticalScrollIndicator = NO;
        _tableSearchView.rowHeight = 36;
        [_tableBGView addSubview:_tableSearchView];
    }

    #pragma mark - 代理
    /* searchBar 代理方法 */
    - (void)searchBar:(UISearchBar *)searchBar textDidChange:(NSString *)searchText{
        // 请求搜索数据 AFN请求后台匹配数据 返回格式是数组格式
        //    NSLog(@"参数%@",self.navView.search.text);
        NSString *token = [[NSUserDefaults standardUserDefaults] objectForKey:@"token"];
        if (!token) {
            token = @"";
        }
        NSDictionary *dic = @{@"token":token,@"keyword":_nav.search.text,@"type":@"1"};
        __weak typeof(self) weakSelf = self;
        [[MSUAFNRequest sharedInstance] postRequestWithURL:@"http://api.showXX100.com/index/compare-res" parameters:dic withBlock:^(id obj, NSError *error) {
            if (obj) {
                weakSelf.dataList = [NSJSONSerialization JSONObjectWithData:obj options:NSJSONReadingMutableLeaves error:nil];
                if (!error) {
                    NSLog(@"访问成功%@",_dataList);
                    // 如果搜索内容不为空,显示 tableBGView
                    if (searchText.length > 0) {
                        weakSelf.tableBGView.hidden = NO;
                        
                        // 如果搜索结果不为空,筛选过滤数据
                        if (weakSelf.dataList.count > 0) {
                            weakSelf.inputString = searchText;
                            NSPredicate *preicate = [NSPredicate predicateWithFormat:@"SELF CONTAINS[c] %@", searchText];
                            if (weakSelf.searchList) {
                                [weakSelf.searchList removeAllObjects];
                            }
                            //过滤数据
                            weakSelf.searchList = [NSMutableArray arrayWithArray:[_dataList filteredArrayUsingPredicate:preicate]];
                            
                        } else{
                            // 清空历史搜索
                            if (weakSelf.searchList.count > 0) {
                                [weakSelf.searchList removeAllObjects];
                            }
                        }
                        //刷新表格
                        [weakSelf.tableSearchView reloadData];
                    }else{
                        weakSelf.tableBGView.hidden = YES;
                    }
                }else{
                    NSLog(@"访问报错%@",error);
                }
            } else{
                [MSUHUD showFileWithString:@"服务器请求为空"];
            }
            
        }];
        
        // 去除搜索框所有文字 或者点击叉叉按钮
        if (!searchText || searchText.length <= 0) {
            _tableBGView.hidden = YES;
        }
    }
    
    /* 搜索按钮点击 */
    - (void)searchBarSearchButtonClicked:(UISearchBar *)searchBar{
        [self searchDidSure];
    }
    
    /* 确定搜索事件 */
    - (void)searchDidSure{
        _tableBGView.hidden = YES;
        [_nav.search resignFirstResponder];
        
        // 请求数据 接口可忽视
        __weak typeof(self) weakSelf = self;
        NSString *token = [[NSUserDefaults standardUserDefaults] objectForKey:@"token"];
        if (!token) {
            token = @"";
        }
        NSDictionary *dic = @{@"keyword":self.nav.search.text,@"token":token};
        [[MSUAFNRequest sharedInstance] postRequestWithURL:@"http://api.showbuy100.com/index/search-following" parameters:dic withBlock:^(id obj, NSError *error) {
            if (obj) {
                NSDictionary *jsonDict = [NSJSONSerialization JSONObjectWithData:obj options:NSJSONReadingMutableLeaves error:nil];
                if (!error) {
                    NSLog(@"访问成功%@",jsonDict);
                    if ([jsonDict[@"code"] isEqualToNumber:[NSNumber numberWithInteger:1]]) {
                        __strong typeof(weakSelf) strongSelf = weakSelf;
    
                        NSDictionary *dic = jsonDict[@"data"];
                        strongSelf.hidesBottomBarWhenPushed = YES;
                        MSUMessageChatController *chat = [[MSUMessageChatController alloc] initWithConversationChatter:dic[@"mobile"] conversationType:EMConversationTypeChat];
                        chat.sellerNickName = dic[@"nickname"];
                        chat.sellerIconUrl = dic[@"avatar"];
                        chat.userId = dic[@"id"];
                        chat.myselfIcon = dic[@"my_avatar"];
                        [strongSelf.navigationController pushViewController:chat animated:YES];
                    }
    
                }else{
                    NSLog(@"访问报错%@",error);
                }
            } else{
                [MSUHUD showFileWithString:@"服务器请求为空"];
            }
            
        }];
    }

    - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section{
        if (self.inputString && self.inputString.length > 0) {
                return [self.searchList count];
            }else{
                return [self.dataList count];
            }
    }

    - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath{
      static NSString *flag = @"cell";
            MSUSearchTableCell *cell=[tableView dequeueReusableCellWithIdentifier:flag];
            if (cell == nil) {
                cell = [[MSUSearchTableCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:flag historyNum:0];
                cell.selectionStyle = UITableViewCellSelectionStyleNone;
            }
            if (self.inputString && self.inputString.length > 0) {
                [UIView animateWithDuration:0.25 animations:^{
                } completion:^(BOOL finished) {
                    _tableBGView.hidden = NO;
                    // 将带属性的字符串添加到cell.textLabel上.
                    if (self.searchList && self.searchList.count>0) {
                        [cell.searLab setAttributedText:[MSUStringTools makeKeyWordAttributedWithSubText:self.inputString inOrigiText:self.searchList[indexPath.row] font:14 color:HEXCOLOR(0xff7e00)]];
                    }
                }];
            }
            else{
                _tableBGView.hidden = YES;
            }
            return cell;
    }

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

推荐阅读更多精彩内容