ios – UISearchBar textDidChange创建错误:重复使用它们后仍有可见的视图:{(null)=(null); }

我正在使用带有UISearchBar的UITableViewController.一切似乎工作正常,除了我在textDidChange方法中得到一个我以前从未见过的奇怪警告.

这是我的代码

- (void)searchBar:(UISearchBar *)searchBar textDidChange:(NSString *)searchText {

    [self.searchResults removeAllObjects];
    if([searchText isEqualToString:@""]||searchText==nil){
        [self.tableView reloadData];
        return;
    }

    for(NSArray *monsterArray in self.monsterArray) {
        NSString *name = monsterArray[0];
        NSRange r = [[name lowercaseString] rangeOfString:[searchText lowercaseString]];
        if(r.location != NSNotFound) {
            if(r.location==0) {
                [self.searchResults addObject:monsterArray];
            }
        }
    }

    [self.tableView reloadData];
}

通过单步执行程序,我发现警告发生在textDidChange结束之前.正如我在标题中提到的,警告是这样的:

There are visible views left after reusing them all: {
(null) = (null);
}

有谁知道为什么会这样,以及如何解决它?

解决方法

我在使用自定义UITextField的节头视图时遇到了类似的问题.我通过在重新加载表视图数据之前调用文本字段上的resignFirstResponder并在重新加载操作之后调用becomeFirstResponder来消除警告.就像是:
// Workaround: hide and show keyboard to prevent warning when reloading results
[self.searchTextField resignFirstResponder];
[self.tableView reloadData];
[self.searchTextField becomeFirstResponder];

相关文章

背景 前端时间产品经理决定使用百度统计,使得 工程B 中原统计sdk-友盟统计,需要被去除。之前尝试去除...
结论: alloc负责分配内存和创建对象对应的isa指针; init只是返回alloc生成的对象。 所以alloc后,多次...
更新 如果UI愿意把启动图切割成n份,按一定约束在launchscreen.storyboard中进行排版,启动图效果会更好...
最近在看一本书《Effective OC 2.0》,今天看到有个tip是OC适中循环各自优劣性,作者最终推荐此块循环。...
// // ViewController.m // paintCodeTestOC //gif // Created by LongMa on 2019/7/25. // #import &a...
背景介绍 一般情况下,出于省电、权限、合理性等因素考虑,给人的感觉是很多奇怪的需求安卓可以实现,但...