两行代码优化搜索

搜索优化

方式一:
用户输入搜索关键字的过程就是一个出栈如栈的过程。我们可以对应的将请求返回的结果出栈入栈。这种方式适用于下面这种情况。以查找单词为例,输入a,a返回的结果包括aa、ab、ac等等,这个时候,再输入b,我们就可以在a返回的结果中搜索,以ab开头的。对于汉语而言,我们可以去汉字的首字母和拼音,如ad可以匹配奥迪,aod也可匹配奥迪。这种使用场合对了,还是可以。但是,要注意系统输入法和第三方输入法的区别。
假设用户想要输入’奥’,对于iOS系统输入放 textDidChanged:(NSString)text会触发很多次。a一次,o一次,选择‘奥’一次。对于搜狗,只有在选择‘奥’时触发一次。

方式二:
判断用户两次输入间的时间间隔,如果大于比如0.5秒,才去取数据,否则不去取数据。textDidChanged一改变就去取,在连续输入时,肯定会卡。
判断时间间隔,对于iOS有一种很简单的做法。

-(void)searchBarTextChanged:(NSString *)searchText {
//searchText变成空
if ([searchText isEqualToString:@""]) {
    //取消前面的请求
} else {
    //取消所有延迟执行的方法,下面的方法带有afterDelay,会被取消。
    [UIViewController cancelPreviousPerformRequestsWithTarget:self];

    //0.5秒后调用startSearchWithKeyword
    [self performSelector:@selector(startSearchWithKeyword:) withObject:searchText afterDelay:0.5];
}

}

cancelPreviousPerformRequestsWithTarget还可以带多个参数,取消特定的selector,可以记住上次searchText,来取消上次搜索。

你可能感兴趣的:(ios,iOS-搜索优化)